亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

springboot如何初始化執(zhí)行sql語句

 更新時間:2021年06月22日 09:50:15   作者:從心歸零  
這篇文章主要介紹了springboot初始化執(zhí)行sql語句的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

springboot初始化執(zhí)行sql語句

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

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

最后查到資料

spring.datasource.schema=classpath:schema.sql

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

我發(fā)現(xiàn)后面才是坑的地方,建立方法。

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

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;|

我這個人做事是步步為營的,都是先在數(shù)據(jù)庫里執(zhí)行了sql語句能用才會寫上去的,但是我發(fā)現(xiàn)在mysql中能使用,放到schema.sql語句中就不好使了。在網(wǎng)上找了半天資料,發(fā)現(xiàn)沒有提到這個問題的

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

當然,這也要配置

spring.datasource.separator=|

這樣就可以了

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

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

springboot項目中自己編寫sql語句并調(diào)用

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

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

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

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

第三步: 在 Controller 中編寫 mapper 的調(diào)用

第四步:編寫 service:

第五步:編寫 service 的實現(xiàn)類:

然后再前端寫方法調(diào)用后端的接口即可

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Java集合之CopyOnWriteArrayList詳解

    Java集合之CopyOnWriteArrayList詳解

    這篇文章主要介紹了Java集合之CopyOnWriteArrayList詳解,CopyOnWriteArrayList是ArrayList的線程安全版本,內(nèi)部也是通過數(shù)組實現(xiàn),每次對數(shù)組的修改都完全拷貝一份新的數(shù)組來修改,修改完了再替換掉老數(shù)組,這樣保證了只阻塞寫操作,需要的朋友可以參考下
    2023-12-12
  • java 教你如何給你的頭像添加一個好看的國旗

    java 教你如何給你的頭像添加一個好看的國旗

    這篇文章主要介紹了java 教你如何給你的頭像添加一個好看的國旗,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • spring通過filter,Interceptor統(tǒng)一處理ResponseBody的返回值操作

    spring通過filter,Interceptor統(tǒng)一處理ResponseBody的返回值操作

    這篇文章主要介紹了spring通過filter,Interceptor統(tǒng)一處理ResponseBody的返回值操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Mybatis的詳細使用教程

    Mybatis的詳細使用教程

    這篇文章主要介紹了Mybatis的詳細使用教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • Java發(fā)送報文與接收報文的實例代碼

    Java發(fā)送報文與接收報文的實例代碼

    這篇文章主要介紹了Java發(fā)送報文與接收報文,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Mybatis-Plus insertBatch執(zhí)行緩慢的原因查詢

    Mybatis-Plus insertBatch執(zhí)行緩慢的原因查詢

    這篇文章主要介紹了Mybatis-Plus insertBatch執(zhí)行緩慢的原因查詢,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Java使用RedisTemplate操作Redis遇到的坑

    Java使用RedisTemplate操作Redis遇到的坑

    這篇文章主要介紹了Java使用RedisTemplate操作Redis遇到的坑,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java 使用Thumbnails對大圖片壓縮

    Java 使用Thumbnails對大圖片壓縮

    這篇文章主要介紹了Java 使用Thumbnails對大圖片壓縮,幫助大家更好的利用Java處理圖片,感興趣的朋友可以了解下
    2020-11-11
  • 教你怎么用Java數(shù)組和鏈表實現(xiàn)棧

    教你怎么用Java數(shù)組和鏈表實現(xiàn)棧

    本篇文章為大家詳細介紹了怎么用Java數(shù)組和鏈表實現(xiàn)棧,文中有非常詳細的代碼示例及注釋,對正在學習java的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • SpringBoot?Loki安裝簡介及實戰(zhàn)思路

    SpringBoot?Loki安裝簡介及實戰(zhàn)思路

    這篇文章主要為大家介紹了SpringBoot?Loki安裝簡介及實戰(zhàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪的相關資料
    2022-11-11

最新評論