亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

springboot初始化執行sql語句的示例分析

發布時間:2021-06-22 11:04:52 來源:億速云 閱讀:213 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關springboot初始化執行sql語句的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

springboot初始化執行sql語句

開發的時候需要增加一些函數和表,同時因為一些基礎數據例如字典表也需要插入一些數據,當然我可以跟組員說一聲然后把sql語句給他們在本地執行,但是這樣太low,不夠自動化。

于是就開始研究如何在springboot啟動時執行sql語句

最后查到資料

spring.datasource.schema=classpath:schema.sql

這個配置項決定建庫文件的位置,注意classpath,之前我在網上查找資料都沒有這個classpath,結果我的schema.sql文件放在哪都不好使,后來加上classpath才好用,文件放在resource下面就行了

我發現后面才是坑的地方,建立方法。

新建方法,首先要先刪掉它,不然會報錯,當然,方法里沒有數據,自然想刪就刪,但是除此之外還有很多坑

drop function if exists `getChildrenProductName`;|
create function `getChildrenProductName`(orgid varchar(50))
returns varchar(4000)
BEGIN
DECLARE `oTemp` VARCHAR(4000);
DECLARE `oTempChild` VARCHAR(4000);
DECLARE `oTempName` VARCHAR(4000);
DECLARE `oTempChildName` VARCHAR(4000);
DECLARE i int;
SET oTemp = CAST(orgid AS CHAR);
SET oTempChild = CAST(orgid AS CHAR);
set oTempName = '$';
set oTempChildName = '';
set i = 0;
WHILE oTempChild IS NOT NULL
DO
if i>0 then
set oTempName = concat(oTempName,",",oTempChildName);
end if;
SET oTemp = CONCAT(oTemp,',',oTempChild);
set i = i +1;
SELECT GROUP_CONCAT(p.product_name,p.partnum) into oTempChildName FROM product p
left join bom b on b.PartID = p.PartID
 WHERE FIND_IN_SET(b.ParentPartID,oTempChild) > 0;
SELECT GROUP_CONCAT(p.PartID) INTO oTempChild FROM product p
left join bom b on b.PartID = p.PartID
 WHERE FIND_IN_SET(b.ParentPartID,oTempChild) > 0;
END WHILE;
RETURN oTempName;
END;|

我這個人做事是步步為營的,都是先在數據庫里執行了sql語句能用才會寫上去的,但是我發現在mysql中能使用,放到schema.sql語句中就不好使了。在網上找了半天資料,發現沒有提到這個問題的

過程就不說了,折騰了半天,我debug才發現,springboot框架把默認是按;號來分割語句的,所以創建函數時,他就把整個創建的語句按;號分割了,自然就報錯了,這就是我在上面使用 | 的原因

當然,這也要配置

spring.datasource.separator=|

這樣就可以了

對了,還有插入數據的需要,因為我是后添加的數據,所以不能重復添加,只有不存在數據才能添加,這個方法是我網上找的,可以用

INSERT INTO table(field1, field2, fieldn) SELECT 'field1', 'field2', 'fieldn' FROM DUAL WHERE NOT EXISTS(SELECT field FROM table WHERE field = ?)

springboot項目中自己編寫sql語句并調用

第一步:在 mapper 的接口中定義方法(使用到的PublishVo對象需要自己定義):

springboot初始化執行sql語句的示例分析

第二步:在 mapper 對應的 xml 文件中寫 SQL 語句:

springboot初始化執行sql語句的示例分析

注意:xml 文件中 select 標簽的 id 屬性就是上一步在 mapper 接口中定義的那個方法名,resultType 就是返回的類型,在上一步的 mapper 接口中的返回類型是自定義的實體類型 PublishVo,因此就寫上實體類 PublishVo 的全路徑。

SQL語句的條件值要使用#,不能使用$,因為$會產生SQL注入問題。

第三步: 在 Controller 中編寫 mapper 的調用

springboot初始化執行sql語句的示例分析

第四步:編寫 service:

springboot初始化執行sql語句的示例分析

第五步:編寫 service 的實現類:

springboot初始化執行sql語句的示例分析

然后再前端寫方法調用后端的接口即可

關于“springboot初始化執行sql語句的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

渝中区| 乌拉特中旗| 城步| 庄河市| 霍邱县| 灵丘县| 沾化县| 本溪市| 伊宁县| 延安市| 衡阳县| 武安市| 金昌市| 潜江市| 合水县| 海宁市| 乌兰县| 青浦区| 兴义市| 河东区| 连城县| 思南县| 锦屏县| 永靖县| 庄浪县| 满洲里市| 湖北省| 夹江县| 萨嘎县| 汉阴县| 玉门市| 北碚区| 旌德县| 舒兰市| 佛教| 新田县| 广平县| 惠水县| 巴彦县| 甘德县| 平遥县|