mybatis?plus中如何編寫sql語句
sql語句是寫在對應(yīng)的xml文件中
首先要解決maven默認(rèn)不加載xml文件的問題
1.首先要寫入相關(guān)配置文件
在pom 導(dǎo)入下面內(nèi)容
?<build> ? ? ? ? <resources> ? ? ? ? ? ? <resource> ? ? ? ? ? ? ? ? <directory>src/main/java</directory> ? ? ? ? ? ? ? ? <includes> ? ? ? ? ? ? ? ? ? ? <include>**/*.xml</include> ? ? ? ? ? ? ? ? </includes> ? ? ? ? ? ? </resource> ? ? ? ? ? ? <resource> ? ? ? ? ? ? ? ? <directory>src/main/resources</directory> ? ? ? ? ? ? </resource> ? ? ? ? </resources> ? ? </build>
在application中寫入如下內(nèi)容
mybatis-plus: ? mapper-locations: classpath*:**/xml/*.xml
2.在對應(yīng)的serviceimpl中調(diào)用baseMapper 接口
應(yīng)為在mybatis plus 中對應(yīng)的serviceImpl 接口繼承自對應(yīng)的mapper接口,mapper接口又繼承自baseMapper 接口。
比如說
baseMapper.countRegisterDay(day)
3.在mapper文件中編寫對應(yīng)的接口
?Integer countRegisterDay(String day);
4.在對應(yīng)的xml 中編寫sql語句
id 為方法的名字。resultType 為方法返回的類型
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.boshrong.ucentor.mapper.UcenterMemberMapper">
? ? <select id="countRegisterDay" resultType="java.lang.Integer">
? ? ? ? select count(*) from ucenter_member um where DATE (um.gmt_create)=#{day}
? ? </select>
</mapper>注意若傳入的值有多個參數(shù)怎么解決?
比如說方法為
?Integer countRegisterDay(String day,String time1);
sql 中獲取多個值的方法可以有兩種
1.方法一 ,通過索引獲取
#{0} 獲取day的值, #{1} 獲取time1的值2.方法二, 通過@Param獲取
Integer countRegisterDay(@Param ("aa")String day,@Param ("bb")String time1);- #{aa},#{bb} 獲取
- #{} 與 ${} 的區(qū)別
- #{} 是預(yù)編譯處理,是占位符。 Mybatis 在處理 #{} 時,會將sql 中的#{} 替換成?號,調(diào)用PreparedStatement 來賦值。
- ${} 是字符串替換,是拼接符。就是會將 KaTeX parse error: Expected 'EOF', got '#' at position 30: …Statement 來賦值。 #?方式能夠很大程度防止sql注入…方式。
mybatis plus sql語句集合
獲取數(shù)據(jù)庫中某個varchar字段的最大值
max(CONVERT(stat_date,UNSIGNED))
日期格式轉(zhuǎn)換
DATE_FORMAT(update_time,‘%Y-%m-%d %T')
字符串拼接
concat(#{year},‘Y')查詢年份的當(dāng)前年份的后面一年
DATE_FORMAT(DATE_SUB(CURDATE(),interval -1 year),‘%Y')
查詢獲取當(dāng)前年份
DATE_FORMAT(CURDATE(),‘%Y')
left,right函數(shù)返回args最左邊、右邊的length個字符串
right(args, 2)
當(dāng)前日期的前三個月日期
pay_time <![CDATA[<]]> now() - INTERVAL 3 MONTH AND now()
截取某一個字段中以某個字符開始截取
- 以從后面開始第一個橫杠為分割截取
SUBSTRING_INDEX( dep_name, ‘-',- 1 ) depName
- 以第一個橫杠為分割截取
SUBSTRING_INDEX( dep_name, ‘-',1 ) depName
IFNULL() 函數(shù)
IFNULL(expression, alt_value)如果第一個參數(shù)的表達(dá)式 expression 為 NULL,則返回第二個參數(shù)的備用值。
- 返回列表中的最大值
GREATEST(expr1, expr2, expr3, …)
- 返回列表中的最小值
LEAST(expr1, expr2, expr3, …)
- 計算日期 d1->d2 之間相隔的天數(shù)
DATEDIFF(d1,d2)
- 如果表達(dá)式 expr 成立,返回結(jié)果 v1;否則,返回結(jié)果 v2。
IF(expr,v1,v2)
find_in_set(str,strlist)
find_in_set判斷是否包含某個字符串str要查詢的字符串strlist字段名 參數(shù)以”,”分隔 如 (1,2,6,8,10,22)- 匹配個字段是否為純數(shù)字 0為匹配純數(shù)字 1為匹配不是純數(shù)字
AND (TRIM(str) REGEXP ‘[^0-9.]') = 0
- 將字符串轉(zhuǎn)換為int數(shù)字類型
CAST(right(yearmth, 2) AS SIGNED)
- 動態(tài)獲取數(shù)據(jù)庫某個字段來作為條件
FIND_IN_SET (year_id,(SELECT GROUP_CONCAT(DISTINCT LEFT(字段, 4)) from table))
locate()函數(shù)
locate(subStr,string):函數(shù)返回subStr在string中出現(xiàn)的位置- 只要找到返回的結(jié)果都大于0(即使是查詢的內(nèi)容就是最開始部分),沒有查找到才返回0;
// 如果字符串 string 包含 subStr locate(subStr,string) > 0 // 如果字符串 string 不包含 subStr locate(subStr,string) = 0
locate()函數(shù)實現(xiàn)模糊查詢
select * from user where locate('王',name)
假如現(xiàn)在需求是找出所有名字中含有王,但是不姓王的人找出來,我們用下面那種實現(xiàn)方式如下:
select * from user where locate('王',name,2)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring之什么是ObjectFactory?什么是ObjectProvider?
這篇文章主要介紹了Spring之什么是ObjectFactory?什么是ObjectProvider?具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
Java 中文字符按Unicode排序的實現(xiàn)方法
這篇文章主要介紹了Java 中文字符按Unicode排序的實現(xiàn)方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10
踩坑之spring事務(wù),非事務(wù)方法與事務(wù)方法執(zhí)行相互調(diào)用方式
這篇文章主要介紹了踩坑之spring事務(wù),非事務(wù)方法與事務(wù)方法執(zhí)行相互調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07

