springboot如何初始化執(zhí)行sql語句
springboot初始化執(zhí)行sql語句
開發(fā)的時候需要增加一些函數(shù)和表,同時因為一些基礎(chǔ)數(shù)據(jù)例如字典表也需要插入一些數(shù)據(jù),當然我可以跟組員說一聲然后把sql語句給他們在本地執(zhí)行,但是這樣太low,不夠自動化。
于是就開始研究如何在springboot啟動時執(zhí)行sql語句
最后查到資料
spring.datasource.schema=classpath:schema.sql
這個配置項決定建庫文件的位置,注意classpath,之前我在網(wǎng)上查找資料都沒有這個classpath,結(jié)果我的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ù),所以不能重復(fù)添加,只有不存在數(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 對應(yīng)的 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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Mybatis-Plus中and()和or()的使用與原理詳解
最近發(fā)現(xiàn)MyBatisPlus還是挺好用的,下面這篇文章主要給大家介紹了關(guān)于Mybatis-Plus中and()和or()的使用與原理的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09
減少代碼開發(fā)工作的Java庫lombok及注解的使用學(xué)習(xí)
不久前發(fā)現(xiàn)有一個java第三方庫可以在一定程度上幫助我們從體力勞動中解救出來,它就是lombok。它提供了一些簡單的注解,并以此來消除java中臃腫的模版代碼。本文對于一些常用到的注解做了一個簡要的記錄,希望有更多的人enjoy it2022-07-07
Mybatis查詢返回Map<String,Object>類型的實現(xiàn)
本文主要介紹了Mybatis查詢返回Map<String,Object>類型的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
SpringBoot基于Disruptor實現(xiàn)高效的消息隊列?
Disruptor是一個開源的Java框架,它被設(shè)計用于在生產(chǎn)者-消費者問題上獲得盡量高的吞吐量和盡量低的延遲,本文主要介紹了SpringBoot基于Disruptor實現(xiàn)高效的消息隊列?,具有一定的參考價值,感興趣的可以了解一下2024-02-02
springmvc使用@notNull注解驗證請求參數(shù)方式
這篇文章主要介紹了springmvc使用@notNull注解驗證請求參數(shù)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教<BR>2024-01-01

