麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Java > 正文

mybatis注解與xml常用語句匯總

2024-07-14 08:42:18
字體:
來源:轉載
供稿:網友

前言

MyBatis是一個支持普通SQL查詢,存儲過程和高級映射的優秀持久層框架。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 != '' ">  </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和數據源的設置參數區別

會被覆蓋。

4.連接參數查詢順序

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

5.druid連接池配置方式:

詳見官網

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

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

7.mybatis默認是事務不提交

總結

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


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天天躁狠狠躁夜躁2020挡不住 | 国产日本在线播放 | 亚洲综合视频网 | 亚洲第一激情 | 日韩视频1| 免费一级在线观看 | 久久久久久久一区二区三区 | 日本在线播放一区二区三区 | 深夜激情视频 | 538任你躁在线精品视频网站 | 午夜视频福利 | 萌白酱福利视频在线网站 | 国产91丝袜在线播放 | 视频一区二区三区在线观看 | hd日本xxxx| 福利在线国产 | 久久不射电影网 | 国产一级淫片在线观看 | 国产pron| 欧美性黄| 免费人成年短视频在线观看网站 | 欧美视频国产精品 | 国产精品视频一区二区三区综合 | 免费一级特黄欧美大片勹久久网 | 全黄性性激高免费视频 | 成人一级黄色大片 | 一级免费在线视频 | 欧美高清第一页 | 91一区二区三区久久久久国产乱 | 国产精品久久久免费观看 | 一级黄色淫片 | 色综合网在线观看 | 少妇一级淫片免费放播放 | 亚洲人成在线播放 | 天堂成人一区二区三区 | 午夜国产精品成人 | 99ri在线| 护士hd老师fre0性xxx | 曰韩一级片 | 色视频欧美 | 久久精品免费网站 |