Mybatis 動態(tài)SQL搭建環(huán)境的全過程
1. Mybatis–動態(tài)SQL
動態(tài) SQL 是 MyBatis 的強大特性之一。如果你使用過 JDBC 或其它類似的框架,你應(yīng)該能理解根據(jù)不同條件拼接 SQL 語句有多痛苦,例如拼接時要確保不能忘記添加必要的空格,還要注意去掉列表最后一個列名的逗號。利用動態(tài) SQL,可以徹底擺脫這種痛苦。
在 MyBatis 之前的版本中,需要花時間了解大量的元素。
借助功能強大的基于 OGNL 的表達式,MyBatis 3 替換了之前的大部分元素,
大大精簡了元素種類,現(xiàn)在要學(xué)習(xí)的元素種類比原來的一半還要少。if
choose (when, otherwise)
trim (where, set)
foreach
1.1 什么是動態(tài)SQL?
動態(tài)SQL就是 指根據(jù)不同的條件生成不同的SQL語句
1.2 搭建環(huán)境
1.2.1 創(chuàng)建表
執(zhí)行此sql語句
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)建時間', `views` INT(30) NOT NULL COMMENT '瀏覽量' )ENGINE=INNODB DEFAULT CHARSET=utf8
執(zhí)行結(jié)果:
1.2.2 創(chuàng)建一個基礎(chǔ)工程
1.2.2.1 導(dǎo)包
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 編寫配置文件
mybatis-config.xml
<!-- 引入外部配置文件--> <properties resource="db.properties"/> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> <!-- 是否開啟駝峰命名自動映射,即從經(jīng)典數(shù)據(jù)庫列名 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 編寫實體類
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; //屬性名和字段名不一致 數(shù)據(jù)庫是 create_time private int views; }
1.2.2.4 編寫實體類對應(yīng)Mapper接口和Mapper.XML文件
BlogMapper.java
package com.tian.dao; import com.tian.pojo.Blog; public interface BlogMapper { // 插入數(shù)據(jù) 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 編寫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()); } }
運行結(jié)果:
1.2.2.6 向表中插入數(shù)據(jù)
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(); } }
運行結(jié)果:
現(xiàn)在我們吧表中的數(shù)據(jù)稍微更改下
總結(jié)
到此這篇關(guān)于Mybatis 動態(tài)SQL搭建環(huán)境的文章就介紹到這了,更多相關(guān)Mybatis動態(tài)SQL環(huán)境內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MyBatis 動態(tài)拼接Sql字符串的問題
- mybatis的動態(tài)sql詳解(精)
- MyBatis 執(zhí)行動態(tài) SQL語句詳解
- Mybatis動態(tài)SQL之if、choose、where、set、trim、foreach標記實例詳解
- oracle+mybatis 使用動態(tài)Sql當插入字段不確定的情況下實現(xiàn)批量insert
- mybatis動態(tài)sql之Map參數(shù)的講解
- MyBatis動態(tài)Sql之if標簽的用法詳解
- MyBatis執(zhí)行動態(tài)SQL的方法
- Mybatis中動態(tài)SQL,if,where,foreach的使用教程詳解
- Mybatis模糊查詢和動態(tài)sql語句的用法
相關(guān)文章
Springboot+Hutool自定義注解實現(xiàn)數(shù)據(jù)脫敏
我們在項目中會處理敏感數(shù)據(jù)時,通常需要對這些數(shù)據(jù)進行脫敏,本文主要使用了Springboot整合Hutool來自定義注解實現(xiàn)數(shù)據(jù)脫敏,感興趣的可以理解下2023-10-10九個動畫組圖輪播總結(jié)全棧數(shù)據(jù)結(jié)構(gòu)數(shù)組鏈表
數(shù)據(jù)結(jié)構(gòu)和算法是密不可分的,兩者往往是相輔相成的存在,所以在學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)過程中,不免會遇到各種算法,數(shù)據(jù)結(jié)構(gòu)常用操作一般為:增刪改查?;旧纤械臄?shù)據(jù)結(jié)構(gòu)都是圍繞這幾個操作進行展開,本文用九張動圖來闡述先進后出的數(shù)據(jù)結(jié)構(gòu)2021-08-08用SpringBoot+Vue+uniapp小程序?qū)崿F(xiàn)在線房屋裝修管理系統(tǒng)
這篇文章主要介紹了用SpringBoot+Vue+uniapp實現(xiàn)在線房屋裝修管理系統(tǒng),針對裝修樣板信息管理混亂,出錯率高,信息安全性差,勞動強度大,費時費力等問題開發(fā)了這套系統(tǒng),需要的朋友可以參考下2023-03-03SpringBoot使用AES對JSON數(shù)據(jù)加密和解密的實現(xiàn)方法
這篇文章主要介紹了SpringBoot使用AES對JSON數(shù)據(jù)加密和解密的實現(xiàn)方法,文章通過代碼示例介紹的非常詳細,對我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-08-08java書店系統(tǒng)畢業(yè)設(shè)計 用戶模塊(3)
這篇文章主要介紹了java書店系統(tǒng)畢業(yè)設(shè)計,第三步系統(tǒng)總體設(shè)計,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10java大數(shù)乘法的簡單實現(xiàn) 浮點數(shù)乘法運算
大數(shù)乘法可以進行任意大小和精度的整數(shù)和浮點數(shù)的乘法運算, 精確度很高, 可以用作經(jīng)融等領(lǐng)域的計算,這個是我看了一些資料, 然后自己整理實現(xiàn)的,簡單測試了一下2014-01-01