mybatis注解與xml常用語句匯總
前言
MyBatis是一個支持普通SQL查詢,存儲過程和高級映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及對結(jié)果集的檢索封裝。MyBatis可以使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJO(Plain Old Java Objects,普通的Java對象)映射成數(shù)據(jù)庫中的記錄。
本文將給大家詳細(xì)介紹關(guān)于mybatis注解與xml常用語句的相關(guān)內(nèi)容,下面話不多說了,來一起看看詳細(xì)的介紹吧
mybatis注解使用
1.簡單crud
public interface UserMapper {
//查詢
@Select("select * from user where id=#{id}")
User selectUser(int id);
//查詢?nèi)?
@Select("select * from user")
List<User> selectUserList();
//增加數(shù)據(jù)
@Insert("insert into user (name) values(#{name})")
boolean insertUser(String name);
//修改用戶
@Update("update user set name=#{name} where id=#{id}")
boolean updateUser(@Param("name") String name,@Param("id") int id);
//刪除用戶
@Delete("delete from user where id=#{id}")
boolean deleteUser(int id);
}
2.一對一注解
@Select("select * from user")
@Results({
@Result(id = true,property = "id",column = "id"),//id=true 對應(yīng)于主鍵
@Result(property = "uid",column = "uid"),
@Result(property = "user",column = "uid",javaType = User.class,
one = @One(select = "com.example.dao.UserDao.findUserByid",fetchType = FetchType.DEFAULT))
//user 對應(yīng)實體類中一對一的實體類名字,uid表示通過uid外鍵查詢User,JavaType表示查詢結(jié)果
//映射成User類型對象,one=表示一對xx fetchType.default默認(rèn)是立即加載全部查詢,使用lazy懶加載需要才查詢
})
List<User> selectUserList();
3,一對多注解
mybatis的xml配置
1.配置resultMap
<resultMap id="BaseResultMap" type="xx" > <id column="id" property="ID" jdbcType="BIGINT" /> <result column="aa" property="aa" jdbcType="VARCHAR" /> <result column="bb" property="bb" jdbcType="INTEGER" /> <result column="cc" property="cc" jdbcType="DECIMAL" javaType="java.math.BigDecimal" /> <result column="dd" property="dd" jdbcType="DATE" /> </resultMap>
2.通用sql短語
<sql id="Base_Column_List" >
aa, bb
</sql>
<sql id="where">
<trim prefix="WHERE" prefixOverrides="AND|OR">
<if test="id != null and id != ''">
AND t.ID = #{id}
</if>
<if test="content != null and content != ''">
AND t.CONTENT LIKE concat('%', #{content},'%')
</if>
AND t.APP_CODE IN
<foreach item="item" index="index" collection="appcodes"
open="(" separator="," close=")">
#{item}
</foreach>
and t.USER_ID=u.id and t.REMOVED=0
</trim>
</sql>
3.需要驗證的插入
<insert id="insert" parameterType="xxx"
useGeneratedKeys="true" keyColumn="id" keyProperty="id">
insert into xxx (
<trim suffixOverrides=",">
<if test="title != null and title != '' ">
TITLE ,
</if>
</trim>
) VALUES (
<trim suffixOverrides=",">
<if test="title != null and title != '' ">
#{title} ,
</if>
</trim>
)
</insert>
4.需要驗證的更新
<update id="update" parameterType="xxx">
UPDATE xxx
<set>
<if test="title != null and title != '' ">
TITLE = #{title} ,
</if>
</set>
WHERE
ID = #{id}
</update>
5.<!--批量更新ticketid和SeatNo-->
<update id="xxxUpdate" parameterType="java.util.List">
update xxx
<trim prefix="set" suffixOverrides=",">
<trim prefix="AA =case" suffix="end,">
<foreach collection="orders" item="item" index="index">
<if test="item.aa !=null">
when ID=#{item.id} then #{item.aa}
</if>
</foreach>
</trim>
<trim prefix="BB =case" suffix="end,">
<foreach collection="orders" item="item" index="index">
<if test="item.bb !=null">
when ID=#{item.id} then #{item.bb}
</if>
</foreach>
</trim>
</trim>
where ID in
<foreach collection="orders" index="index" item="item" separator="," open="(" close=")">
#{item.id,jdbcType=BIGINT}
</foreach>
</update>
mybatis可以使用string給數(shù)據(jù)庫int類型賦值
springboot中開啟日志
#mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
1.ORDER BY ${columnName}
這里 MyBatis 不會修改或轉(zhuǎn)義字符串。NOTE 用這種方式接受用戶的輸入,并將其用于語句中的參數(shù)是不安全的,會導(dǎo)致潛在的 SQL 注入攻擊,因此要么不允許用戶輸入這些字段,要么自行轉(zhuǎn)義并檢驗。
2.如何使用連接池。
首先實例化連接池數(shù)據(jù)源對象,讓他實現(xiàn)DataSourceFactory這個接口。然后實現(xiàn)方法。在mybatis。conf文件中設(shè)置數(shù)據(jù)連接池這個類,將數(shù)據(jù)庫連接信息放在config.properties文件中。
3.mybatis.config文件中setting和數(shù)據(jù)源的設(shè)置參數(shù)區(qū)別
會被覆蓋。
4.連接參數(shù)查詢順序
首先查詢properties文件,然后查詢resource文件,最后查詢方法參數(shù)。重復(fù)的話會被覆蓋。
5.druid連接池配置方式:
詳見官網(wǎng)
DruidDataSourceFactory首先實行setproperties方法,然后返回設(shè)置數(shù)據(jù)源方法。drui數(shù)據(jù)源也需要在DataSource中設(shè)置properties文件
6.實體類的方法不定義也可以進(jìn)行映射
7.mybatis默認(rèn)是事務(wù)不提交
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
詳解Spring系列之@ComponentScan批量注冊bean
本文介紹各種@ComponentScan批量掃描注冊bean的基本使用以及進(jìn)階用法和@Componet及其衍生注解使用,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2022-02-02
Java微信公眾平臺開發(fā)(3) 接收消息的分類及實體的創(chuàng)建
這篇文章主要為大家詳細(xì)介紹了Java微信公眾平臺開發(fā)第三步,接收消息的分類及實體的創(chuàng)建,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
SpringBoot2.x 整合Spring-Session實現(xiàn)Session共享功能
這篇文章主要介紹了SpringBoot2.x 整合Spring-Session實現(xiàn)Session共享功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
JAVA將中文轉(zhuǎn)換為拼音簡單實現(xiàn)方法
拼音轉(zhuǎn)換是中文處理的常見需求,TinyPinyin、HanLP、pinyin4j是常用的本地拼音轉(zhuǎn)換庫,各有特點,開發(fā)者可根據(jù)具體需求選擇合適的拼音轉(zhuǎn)換工具,需要的朋友可以參考下2024-10-10
詳解Java如何實現(xiàn)與JS相同的Des加解密算法
這篇文章主要介紹了如何在Java中實現(xiàn)與JavaScript相同的DES(Data Encryption Standard)加解密算法,確保在兩個平臺之間可以無縫地傳遞加密信息,希望對大家有一定的幫助2025-04-04

