CREATE DEFINER=wantbpm_uat@10.%.%.% PROCEDURE wantbpm_uat.P_MATERIAL() proc_label:BEGIN DECLARE _st INT(10) DEFAULT UNIX_TIMESTAMP(); DECLARE _cnts1 INT ; select count(*) into _cnts1 from ods.dm_d_material; if _cnts1<1 then SELECT CONCAT('; P_MATERIAL出错,ods数据量异常 ', (UNIX_TIMESTAMP()-_st) ) AS INFO; LEAVE proc_label; -- 跳出存储过程 end if; truncate table wantbpm_uat.MATERIAL; insert into wantbpm_uat.MATERIAL SELECT DIM_MATERIAL_ID, REC_CREATE_DATE, MATERIAL, CONVERT(MATL_NAME, USING utf8), MATL_SPECS, MATL_TYPE, MATL_TYPE_NAME, MATL_GROUP, MATL_GROUP_NAME, PRODUCT_GROUP, PRODUCT_GROUP_NAME, BASIC_UNIT, BASIC_UNIT_NAME, MIN_UNIT, MIN_UNIT_NAME, EXT_MATL_GROUP, EXT_MATL_GROUP_NAME, GROSS_WEIGHT, NET_WEIGHT, SALES_PRICE, MATL_HIER, MATL_HIER1, MATL_HIER1_NAME, MATL_HIER2, MATL_HIER2_NAME, MATL_HIER3, MATL_HIER3_NAME, MATL_HIER4, MATL_HIER4_NAME, MATL_HIER5, MATL_HIER5_NAME, TERM_CATEG, TERM_CATEG_NAME, MATL_COMB, MATL_COMB_NAME, MATL_SCALE, MATL_SCALE_NAME, FUNCTION_CATEG, FUNCTION_CATEG_NAME, MATL_MAIN_CATEG, GENERAL_CATEG_UNIT, GENERAL_CATEG_UNIT_NAME, MATL_SCALE_FI, MATL_NEW, BRAND, BRAND_NAME, REC_CREATOR, REC_UPDATE_DATE, REC_UPDATER, MATL_OLD, MATL_CATEG, MATL_BOX_SIZE, ERP_MATL_PROPERTY1, ERP_MATL_PROPERTY2, ERP_MATL_PROPERTY3, ERP_MATL_PROPERTY4, ERP_MATL_PROPERTY5, ERP_MATL_PROPERTY6, ERP_MATL_PROPERTY7, CDP_MATL_FLAG1, CDP_MATL_FLAG2, CDP_MATL_FLAG3, TAX_RATE, INSERT_DATETIME, UPDATE_DATETIME FROM ods.dm_d_material; SELECT CONCAT( ' P_MATERIAL END - ', (UNIX_TIMESTAMP()-_st) ) AS INFO; END
时间: 2023-09-13 15:03:24 浏览: 78
这是一个 MySQL 存储过程,作用是从 ods.dm_d_material 表中获取物料信息并插入到 wantbpm_uat.MATERIAL 表中。在存储过程中,先判断 ods.dm_d_material 表中是否有数据,如果没有数据则会输出错误信息并跳出存储过程,否则会执行插入操作,并输出执行时间信息。
相关问题
create definer=`root`@`%` proc
您可以使用以下的语法来创建一个以`root`用户为定义者的存储过程:
```sql
CREATE DEFINER=`root`@`%` PROCEDURE procedure_name()
BEGIN
-- 存储过程的逻辑
END;
```
在上述代码中,您需要将`procedure_name`替换为您所创建的存储过程的名称,并在`BEGIN`和`END`之间编写您的存储过程逻辑。请注意,`definer`指定了存储过程的创建者,`root`表示MySQL中的根用户,而`%`表示可以从任何主机连接到数据库服务器。根据您的实际需求,您可以根据具体的用户和主机进行修改。
CREATE DEFINER=`root`@`localhost` FUNCTION `get_borrower_name`(p_bookid char(20)) RETURNS char(10) CHARSET utf8mb4 begin declare v_name char(10); select name into v_name from borrowers b join borrow_info bi on b.id = bi.id join books bk on bk.bookid = bi.bookid where bi.bookid = p_bookid; return v_name; end select bk.bookname,get_borrower_name(bk.bookid) as borrower_name from books bk join borrow_info bi on bk.bookid = bi.bookid where bk.in_out = true and bi.return_date is null and get_borrower_name(bk.bookid) = '张三';出现 Result consisted of more than one row错误
这个错误可能是因为你的`get_borrower_name()`函数返回了多行数据,而你在查询中使用了这个函数,并且设置了`get_borrower_name(bk.bookid) = '张三'`的条件,这样可能会导致查询结果出现多行数据。可以尝试修改查询条件,或者修改`get_borrower_name()`函数,让它只返回一行数据。比如,你可以修改函数,让它只返回第一个匹配的借阅者姓名:
```
CREATE DEFINER=`root`@`localhost` FUNCTION `get_borrower_name`(p_bookid char(20)) RETURNS char(10) CHARSET utf8mb4
BEGIN
DECLARE v_name CHAR(10);
SELECT name INTO v_name FROM borrowers b
JOIN borrow_info bi ON b.id = bi.id
JOIN books bk ON bk.bookid = bi.bookid
WHERE bi.bookid = p_bookid LIMIT 1;
RETURN v_name;
END
```
这个函数使用了`LIMIT 1`语句,表示只返回第一行匹配的数据。这样就可以避免函数返回多行数据的问题了。如果你还是想保留原来的函数逻辑,可以尝试修改查询条件,让它返回唯一的一行数据。比如,你可以修改查询条件,让它只返回第一本被借阅的图书:
```
SELECT bk.bookname, get_borrower_name(bk.bookid) AS borrower_name
FROM books bk
JOIN (
SELECT bookid FROM borrow_info
WHERE return_date IS NULL AND borrower_name = '张三'
ORDER BY borrow_date ASC LIMIT 1
) bi ON bk.bookid = bi.bookid
WHERE bk.in_out = true;
```
这个查询使用了子查询和ORDER BY语句,表示只返回第一本被借阅的图书。这样也可以避免查询结果出现多行数据的问题。
阅读全文