中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis中注解怎么用

發布時間:2021-07-26 14:11:19 來源:億速云 閱讀:173 作者:小新 欄目:編程語言

小編給大家分享一下Mybatis中注解怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Mybatis 除了 XML 配置寫法,還可以使用注解寫法。

首先需要引入 Mybatis 的依賴:

<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>1.3.2</version>
</dependency>
<dependency>
  <groupId>tk.mybatis</groupId>
  <artifactId>mapper-spring-boot-starter</artifactId>
  <version>1.1.3</version>
</dependency>

然后在接口上打上對應 @Mapper 注解

Mybatis中注解怎么用

下面是常用的 Myatis 注解寫法:

【1】新增對象( 非自增 ID )

插入的時候,數據庫的值字段會自動匹配對象中同名稱屬性的值。

@Insert(value = { "INSERT INTO user (id, name, age, remark) VALUES (#{id}, #{name}, #{age}, #{remark})" })
public void addUser(User user);

【2】新增對象( 自增 ID )

如果數據庫user表的 id 是自增長,我們可以加上 @Options 注解,那么該對象在插入后,id 屬性會自動獲取到主鍵。

@Options(useGeneratedKeys=true, keyProperty="id") 其中的 id 對應數據庫表中的主鍵字段。

@Insert(value = { "INSERT INTO user (name, age, remark) VALUES (#{name}, #{age}, #{remark})" })
@Options(useGeneratedKeys=true, keyProperty="id")
public void insertUser(User user);

【3】根據 ID 查詢對象

 @Param(value = "id") 其中的 id 對應 SQL 語句中的 #{id}

@Select("SELECT * FROM user WHERE id = #{id}")
public User getUserById(@Param(value = "id") long id);

在查詢對象的過程中,表字段會自動裝箱給同名屬性。當然,也可以寫成綁定形式。

如下:@Result 注解中 property 是對象字段,column 是表字段。

@Select("SELECT * FROM user WHERE id = #{id}")
@Results({
 @Result(property="id", column="id"),
 @Result(property="name", column="name"), 
 @Result(property="age", column="age"), 
 @Result(property="remark", column="remark"), 
})
public User getUserById(@Param(value = "id") long id);

【4】大于 ( > ) 查詢

在SQL 語句中,直接寫作 > ,但在 xml 中,大于通常用轉義 &gt; 替代 ( xml 寫法介紹詳見 6.2)。

@Select("SELECT * FROM user WHERE age > #{age}")
public List<User> getUserList(@Param(value = "age") Integer age);

【5】小于 ( < ) 查詢

在SQL 語句中,直接寫作 < ,但在 xml 中,小于通常用轉義 &lt; 替代  ( xml 寫法介紹詳見 6.2)。

@Select("SELECT * FROM user WHERE age < #{age}")
public List<User> getUserList(@Param(value = "age") Integer age);

【6】IN 關鍵字查詢

(6.1)帶 IN 的子查詢

@Select("SELECT * FROM user WHERE id IN (SELECT id FROM user WHERE name = #{name})")
public List<User> getUserList(@Param(value = "name") String name);

(6.2)帶 IN 的集合查詢

List 集合,Set集合,數組 都適用。

注意:@Select({"<script>", "xx1", "xx2", "</script>"}) 這種寫法為 xml 方式寫法。所有 SQL 都在 <script> </script> 這對標簽之中,標簽之外是一對大括號,<script> 標簽內的所有參數在最后執行 SQL 的時候會自動拼接,如這里為 xx1xx2,以此類推。 <script> 標簽內還可以內嵌標簽,比如下面里的 <foreach>,標簽內所有引號都為單引號。

@Select({"<script>", "SELECT * FROM user WHERE id IN ", 
 "<foreach collection='ids' item='id' open='(' separator=',' close=')'>#{id}</foreach>", "</script>"})
public List<User> getUserList(@Param(value = "ids") List<Long> ids);

在 Postgrelsql 中,如果邏輯SQL中的 IN 和 ANY 的語義相同,那么盡量用 ANY,這樣會更加效率。如:

@Select("SELECT * FROM user WHERE id = ANY(#{ids}::integer[])")
public List<SubOrderPO> getUserList(@Param(value = "ids") Integer[] ids);

【7】LIKE 關鍵字查詢

@Select("SELECT * FROM user WHERE name LIKE concat('%', #{name}, '%') ")
public List<User> getUserList(@Param(value = "name") String name);

【8】時間查詢

(8.1)Date 類型:直接傳入進行比較

@Select("SELECT * FROM user WHERE create_time > #{createTime}")
public List<User> test(@Param(value = "createTime") Date createTime);

(8.2)String 類型:需要將其轉化( 時間精度可以按自己需要裁取 )

Mysql :STR_TO_DATE('2008-08-08 08:08:08', '%Y-%m-%d %H:%i:%s')

Postgrelsql :to_timestamp('2008-08-08 08:08:08','yyyy-MM-dd hh34:mi:ss')

Oracle : to_date( '2008-08-08 08:08:08' , 'yyyy-MM-dd HH24:mi:ss' )

如 Mysql 寫法:

@Select("SELECT * FROM user WHERE create_time > STR_TO_DATE(#{createTime}, '%Y-%m-%d %H:%i:%s')")
public List<User> test(@Param(value = "createTime") String createTime);

【9】高級查詢( 動態SQL )

 注意:【&gt;】是大于(>)的轉義,【&lt;】 是小于(<)的轉義

@Select({"<script>", "SELECT * FROM user ","<where>",
 "<if test = 'name != null' >", " AND name LIKE concat('%', #{name}, '%') ", "</if>", 
 "<if test = 'age != null and age != 0' >", " AND age &lt; #{age} ", "</if>", 
 "</where>", "</script>"})
public List<User> getUserList(@Param(value = "name") String name, @Param(value = "age") Integer age);

【10】修改對象

@Update("UPDATE user SET name = #{name} WHERE id = #{id}")
public void update(@Param(value = "id") Long id, @Param(value = "name") String name);

【11】刪除對象

@Delete("Delete FROM user WHERE id = #{id}")
public void delete(@Param(value = "id") Long id);

以上是“Mybatis中注解怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宝清县| 洛川县| 上高县| 崇明县| 获嘉县| 乌兰察布市| 宁波市| 兴海县| 平乐县| 忻州市| 乐昌市| 兴城市| 廉江市| 江城| 漳平市| 合作市| 民权县| 青川县| 滦平县| 睢宁县| 沂南县| 宁远县| 四会市| 耒阳市| 天等县| 扶绥县| 莱州市| 济南市| 辉南县| 体育| 南部县| 永德县| 新野县| 阿城市| 开阳县| 凤凰县| 顺义区| 凤冈县| 宣武区| 栖霞市| 麦盖提县|