- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > 編程語(yǔ)言 >
- Mybatis 動(dòng)態(tài)SQL搭建環(huán)境的全過(guò)程
動(dòng)態(tài) SQL 是 MyBatis 的強大特性之一。如果你使用過(guò) JDBC 或其它類(lèi)似的框架,你應該能理解根據不同條件拼接 SQL 語(yǔ)句有多痛苦,例如拼接時(shí)要確保不能忘記添加必要的空格,還要注意去掉列表最后一個(gè)列名的逗號。利用動(dòng)態(tài) SQL,可以徹底擺脫這種痛苦。
在 MyBatis 之前的版本中,需要花時(shí)間了解大量的元素。
借助功能強大的基于 OGNL 的表達式,MyBatis 3 替換了之前的大部分元素,
大大精簡(jiǎn)了元素種類(lèi),現在要學(xué)習的元素種類(lèi)比原來(lái)的一半還要少。if
choose (when, otherwise)
trim (where, set)
foreach
1.1 什么是動(dòng)態(tài)SQL?
動(dòng)態(tài)SQL就是 指根據不同的條件生成不同的SQL語(yǔ)句
1.2 搭建環(huán)境
1.2.1 創(chuàng )建表
執行此sql語(yǔ)句
CREATE TABLE `blog`( `id` VARCHAR(50) NOT NULL COMMENT '博客id', `title` VARCHAR(100) NOT NULL COMMENT '博客標題', `author` VARCHAR(30) NOT NULL COMMENT '博客作者', `create_time` DATETIME NOT NULL COMMENT '創(chuàng )建時(shí)間', `views` INT(30) NOT NULL COMMENT '瀏覽量' )ENGINE=INNODB DEFAULT CHARSET=utf8
執行結果:
1.2.2 創(chuàng )建一個(gè)基礎工程
1.2.2.1 導包
pom.xml
<dependencies> <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.12</version> <scope>provided</scope> </dependency> </dependencies>
1.2.2.2 編寫(xiě)配置文件
mybatis-config.xml
<!-- 引入外部配置文件--> <properties resource="db.properties"/> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> <!-- 是否開(kāi)啟駝峰命名自動(dòng)映射,即從經(jīng)典數據庫列名 A_COLUMN 映射到經(jīng)典 Java 屬性名 aColumn。 --> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings> <typeAliases> <typeAlias type="com.tian.pojo.Blog" alias="Blog"/> </typeAliases>
1.2.2.3 編寫(xiě)實(shí)體類(lèi)
Blog.java
package com.tian.pojo; import lombok.Data; import java.util.Date; @Data public class Blog { private String id; private String title; private String author; private Date createTime; //屬性名和字段名不一致 數據庫是 create_time private int views; }
1.2.2.4 編寫(xiě)實(shí)體類(lèi)對應Mapper接口和Mapper.XML文件
BlogMapper.java
package com.tian.dao; import com.tian.pojo.Blog; public interface BlogMapper { // 插入數據 int addBlog(Blog blog); }
BlogMapper.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.tian.dao.BlogMapper"> <insert id="addBlog" parameterType="Blog"> insert into mybatis.blog(id, title, author, create_time, views) values (#{id}, #{title}, #{author}, #{createTime}, #{views}); </insert> </mapper>
1.2.2.5 編寫(xiě)IDUtils .java用于生成隨機的ID
IDUtils .java
package com.tian.util; import org.junit.Test; import java.util.UUID; @SuppressWarnings("all") // 忽略所有警告 public class IDUtils { public static String getId() { return UUID.randomUUID().toString().replaceAll("-", ""); } @Test public void test() { System.out.println(getId()); System.out.println(getId()); System.out.println(getId()); System.out.println(getId()); System.out.println(getId()); System.out.println(getId()); } }
運行結果:
1.2.2.6 向表中插入數據
Test.java
import com.tian.dao.BlogMapper; import com.tian.pojo.Blog; import com.tian.util.IDUtils; import com.tian.util.MybatisUtils; import org.apache.ibatis.session.SqlSession; import java.util.Date; public class Test { @org.junit.Test public void test() { SqlSession sqlSession = MybatisUtils.getSqlSession(); BlogMapper mapper = sqlSession.getMapper(BlogMapper.class); Blog blog = new Blog(); blog.setId(IDUtils.getId()); blog.setTitle("Mybatis"); blog.setAuthor("天天天"); blog.setCreateTime(new Date()); blog.setViews(9999); mapper.addBlog(blog); blog.setId(IDUtils.getId()); blog.setTitle("Java"); mapper.addBlog(blog); blog.setId(IDUtils.getId()); blog.setTitle("Spring"); mapper.addBlog(blog); blog.setId(IDUtils.getId()); blog.setTitle("微服務(wù)"); mapper.addBlog(blog); sqlSession.close(); } }
運行結果:
現在我們吧表中的數據稍微更改下
到此這篇關(guān)于Mybatis 動(dòng)態(tài)SQL搭建環(huán)境的文章就介紹到這了,更多相關(guān)Mybatis動(dòng)態(tài)SQL環(huán)境內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站