欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis注解與xml常用語句匯總

 更新時間:2018年09月10日 11:18:03   作者:wotrd  
最近一直在用mybatis,由于需要使用到了動態(tài)sql,遇到了一些問題,現在來總結一下,經驗教訓。下面這篇文章主要給大家總結介紹了mybatis注解與xml常用語句的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下

前言

MyBatis是一個支持普通SQL查詢,存儲過程和高級映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數的手工設置以及對結果集的檢索封裝。MyBatis可以使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJO(Plain Old Java Objects,普通的Java對象)映射成數據庫中的記錄。

本文將給大家詳細介紹關于mybatis注解與xml常用語句的相關內容,下面話不多說了,來一起看看詳細的介紹吧

mybatis注解使用

1.簡單crud

public interface UserMapper {
 //查詢
 @Select("select * from user where id=#{id}")
 User selectUser(int id);
 //查詢全部
 @Select("select * from user")
 List<User> selectUserList();
 //增加數據
 @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 對應于主鍵
 @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 對應實體類中一對一的實體類名字,uid表示通過uid外鍵查詢User,JavaType表示查詢結果
 //映射成User類型對象,one=表示一對xx fetchType.default默認是立即加載全部查詢,使用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給數據庫int類型賦值

springboot中開啟日志

#mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

1.ORDER BY ${columnName}

這里 MyBatis 不會修改或轉義字符串。NOTE 用這種方式接受用戶的輸入,并將其用于語句中的參數是不安全的,會導致潛在的 SQL 注入攻擊,因此要么不允許用戶輸入這些字段,要么自行轉義并檢驗。

2.如何使用連接池。

首先實例化連接池數據源對象,讓他實現DataSourceFactory這個接口。然后實現方法。在mybatis。conf文件中設置數據連接池這個類,將數據庫連接信息放在config.properties文件中。

3.mybatis.config文件中setting和數據源的設置參數區(qū)別

會被覆蓋。

4.連接參數查詢順序

首先查詢properties文件,然后查詢resource文件,最后查詢方法參數。重復的話會被覆蓋。

5.druid連接池配置方式:

詳見官網

DruidDataSourceFactory首先實行setproperties方法,然后返回設置數據源方法。drui數據源也需要在DataSource中設置properties文件

6.實體類的方法不定義也可以進行映射

7.mybatis默認是事務不提交

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • 自定義feignClient的常見坑及解決

    自定義feignClient的常見坑及解決

    這篇文章主要介紹了自定義feignClient的常見坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • springcloud初體驗(真香)

    springcloud初體驗(真香)

    這篇文章主要介紹了springcloud初體驗(真香),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • Java中new Date().getTime()指定時區(qū)的時間戳問題小結

    Java中new Date().getTime()指定時區(qū)的時間戳問題小結

    本文主要介紹了Java中new Date().getTime()時間戳問題小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • Python學習之書寫格式及變量命名

    Python學習之書寫格式及變量命名

    這篇文章我們給大家總結了關于Python書寫格式及變量命名,小編覺得這篇文章寫的還不錯,有興趣的朋友跟著參考學習下,希望能夠給你帶來幫助
    2021-10-10
  • Java配置HTTP/Socks代理的簡單快速上手方法

    Java配置HTTP/Socks代理的簡單快速上手方法

    這篇文章主要為大家介紹了Java配置HTTP/Socks代理的簡單快速上手方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • java截取圖片示例

    java截取圖片示例

    這篇文章主要介紹了java截取圖片示例,把代碼中的圖片路徑改成自己的圖片,運行就可以看到效果了,需要的朋友可以參考下
    2014-03-03
  • Spring中自動裝配的4種方式

    Spring中自動裝配的4種方式

    今天小編就為大家分享一篇關于Spring中自動裝配的4種方式,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Elasticsearch(ES)多種查詢方式案例

    Elasticsearch(ES)多種查詢方式案例

    Elasticsearch是一個分布式的RESTful搜索和分析引擎,可讓您輕松地大規(guī)模存儲,搜索和分析,這篇文章主要給大家介紹了關于Elasticsearch(ES)多種查詢方式的相關資料,需要的朋友可以參考下
    2023-09-09
  • Java開發(fā)之內部類對象的創(chuàng)建及hook機制分析

    Java開發(fā)之內部類對象的創(chuàng)建及hook機制分析

    這篇文章主要介紹了Java開發(fā)之內部類對象的創(chuàng)建及hook機制,結合實例形式分析了java基于hook機制內部類對象的創(chuàng)建與使用,需要的朋友可以參考下
    2018-01-01
  • SpringBoot中整合JodConverter實現文件在線預覽功能

    SpringBoot中整合JodConverter實現文件在線預覽功能

    Spring Boot JodConverter是一個基于Spring Boot框架的文檔轉換工具,它使用JodConverter庫來實現文檔格式之間的轉換,本文主要介紹了SpringBoot中整合JodConverter實現文件在線預覽功能,需要的朋友可以參考下
    2024-04-04

最新評論