mybatis注解與xml常用語句匯總
前言
MyBatis是一個(gè)支持普通SQL查詢,存儲(chǔ)過程和高級(jí)映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及對(duì)結(jié)果集的檢索封裝。MyBatis可以使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJO(Plain Old Java Objects,普通的Java對(duì)象)映射成數(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.一對(duì)一注解
@Select("select * from user") @Results({ @Result(id = true,property = "id",column = "id"),//id=true 對(duì)應(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 對(duì)應(yīng)實(shí)體類中一對(duì)一的實(shí)體類名字,uid表示通過uid外鍵查詢User,JavaType表示查詢結(jié)果 //映射成User類型對(duì)象,one=表示一對(duì)xx fetchType.default默認(rèn)是立即加載全部查詢,使用lazy懶加載需要才查詢 }) List<User> selectUserList();
3,一對(duì)多注解
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.需要驗(yàn)證的插入
<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.需要驗(yàn)證的更新
<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 不會(huì)修改或轉(zhuǎn)義字符串。NOTE 用這種方式接受用戶的輸入,并將其用于語句中的參數(shù)是不安全的,會(huì)導(dǎo)致潛在的 SQL 注入攻擊,因此要么不允許用戶輸入這些字段,要么自行轉(zhuǎn)義并檢驗(yàn)。
2.如何使用連接池。
首先實(shí)例化連接池?cái)?shù)據(jù)源對(duì)象,讓他實(shí)現(xiàn)DataSourceFactory這個(gè)接口。然后實(shí)現(xiàn)方法。在mybatis。conf文件中設(shè)置數(shù)據(jù)連接池這個(gè)類,將數(shù)據(jù)庫連接信息放在config.properties文件中。
3.mybatis.config文件中setting和數(shù)據(jù)源的設(shè)置參數(shù)區(qū)別
會(huì)被覆蓋。
4.連接參數(shù)查詢順序
首先查詢properties文件,然后查詢r(jià)esource文件,最后查詢方法參數(shù)。重復(fù)的話會(huì)被覆蓋。
5.druid連接池配置方式:
詳見官網(wǎng)
DruidDataSourceFactory首先實(shí)行setproperties方法,然后返回設(shè)置數(shù)據(jù)源方法。drui數(shù)據(jù)源也需要在DataSource中設(shè)置properties文件
6.實(shí)體類的方法不定義也可以進(jìn)行映射
7.mybatis默認(rèn)是事務(wù)不提交
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Java中new Date().getTime()指定時(shí)區(qū)的時(shí)間戳問題小結(jié)
本文主要介紹了Java中new Date().getTime()時(shí)間戳問題小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07Java開發(fā)之內(nèi)部類對(duì)象的創(chuàng)建及hook機(jī)制分析
這篇文章主要介紹了Java開發(fā)之內(nèi)部類對(duì)象的創(chuàng)建及hook機(jī)制,結(jié)合實(shí)例形式分析了java基于hook機(jī)制內(nèi)部類對(duì)象的創(chuàng)建與使用,需要的朋友可以參考下2018-01-01SpringBoot中整合JodConverter實(shí)現(xiàn)文件在線預(yù)覽功能
Spring Boot JodConverter是一個(gè)基于Spring Boot框架的文檔轉(zhuǎn)換工具,它使用JodConverter庫來實(shí)現(xiàn)文檔格式之間的轉(zhuǎn)換,本文主要介紹了SpringBoot中整合JodConverter實(shí)現(xiàn)文件在線預(yù)覽功能,需要的朋友可以參考下2024-04-04