如何使用 Mybatis 实现数据库 CURD 操作?


作者?|?阿文,责编 | 郭芮
头图 | CSDN 下载自东方IC
出品 | CSDN(ID:CSDNnews)

准备工作
idea maven mysql

创建数据库并插入数据
mysql>?create?database?mybatis_db;
Query?OK,?1?row?affected?(0.01?sec)
mysql>?use?mybatis_db;
Database?changed
mysql>?create?table?t_user(
????->?id?int(32)?primary?key?auto_increment,
????->?username?varchar(50),
????->?jobs?varchar(50),
????->?phone?varchar(16));
Query?OK,?0?rows?affected,?1?warning?(0.01?sec)
mysql>?insert?into?t_user?values(1,"zhangsan","teacher","13142767333");
Query?OK,?1?row?affected?(0.01?sec)
mysql>?insert?into?t_user?values(2,"lisi","engineer","13142767334");
Query?OK,?1?row?affected?(0.01?sec)
mysql>?insert?into?t_user?values(3,"wangwu","pilot","12342767334");
Query?OK,?1?row?affected?(0.00?sec)
mysql>

配置pom.xml 下载jar包
?<dependency>
??????<groupId>org.mybatis</groupId>
??????<artifactId>mybatis</artifactId>
??????<version>3.5.4</version>
????</dependency>
????<dependency>
??????<groupId>mysql</groupId>
??????<artifactId>mysql-connector-java</artifactId>
??????<version>8.0.19</version>
????</dependency>


配置mybatis-config
src\main目录点击右键创建一个目录,创建的时候选择resource即可),内容如下,具体不需要过多解释,该配置文件主要是定义JDBC相关的参数包括使用的驱动、mysql 访问地址、用户名和密码以及通过mappers 定义一个mybatis 的映射文件。<?xml?version="1.0"?encoding="UTF-8"?>
<!DOCTYPE?configuration?PUBLIC?"-//mybatis.org//DTD?Config?3.0//EN"
????????"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
????<environments?default="mysql">
????????<environment?id="mysql">
????????????<transactionManager?type="JDBC"?/>
????????????<dataSource?type="POOLED">
????????????????<property?name="driver"?value="com.mysql.jdbc.Driver"?/>
????????????????<property?name="url"?value="jdbc:mysql://192.168.10.128:3306/mybatis_db"?/>
????????????????<property?name="username"?value="root"?/>
????????????????<property?name="password"?value="123456"?/>
????????????</dataSource>
????????</environment>
????</environments>
????<mappers>
????????<mapper?resource="UserMapper.xml"?/>
????</mappers>
</configuration>

创建user类

package?com.mybatis;
public?class?User?{
????private?Integer?id;
????private?String?username;
????private?String?jobs;
????private?String?phone;
????public?Integer?getId()?{
????????return?id;
????}
????public?String?getUsername()?{
????????return?username;
????}
????public?String?getJobs()?{
????????return?jobs;
????}
????public?String?getPhone()?{
????????return?phone;
????}
????public?void?setId(Integer?id)?{
????????this.id?=?id;
????}
????public?void?setUsername(String?username)?{
????????this.username?=?username;
????}
????public?void?setJobs(String?jobs)?{
????????this.jobs?=?jobs;
????}
????public?void?setPhone(String?phone)?{
????????this.phone?=?phone;
????}
????@Override
????public?String?toString()?{
????????return?"User{"?+
????????????????"id="?+?id?+
????????????????",?username='"?+?username?+?'\''?+
????????????????",?jobs='"?+?jobs?+?'\''?+
????????????????",?phone='"?+?phone?+?'\''?+
????????????????'}';
????}
}

创建测试类
<?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="UserMapper">
????<!--根据用户编号获取用户信息?-->
????<select?id="findUserById"?parameterType="Integer"?resultType="com.mybatis.User">
????????select?*?from?t_user?where?id=#{id}
????</select>
</mapper>
package?com.mybatis;
import?java.io.InputStream;
import?org.apache.ibatis.io.Resources;
import?org.apache.ibatis.session.SqlSession;
import?org.apache.ibatis.session.SqlSessionFactory;
import?org.apache.ibatis.session.SqlSessionFactoryBuilder;
import?org.junit.jupiter.api.Test;
/**
?*?@Auth:?xxxx
?*?@E-mail:?xxx
?*?@title:?MybatisTest
?*?@projectName:?mybatis
?*?@description:?TODO?描述信息
?*?@Date?2020/4/7?9:15?下午
?**/
public?class?MybatisTest?{
????@Test
????public?void?findUserByIdTest()?throws?Exception?{
????????String?resource?=?"mybatis-config.xml";
????????InputStream?inputStream?=?Resources.getResourceAsStream(resource);
????????SqlSessionFactory?sqlSessionFactory?=?new?SqlSessionFactoryBuilder().build(inputStream);
????????SqlSession?sqlSession?=?sqlSessionFactory.openSession();
????????User?user?=?sqlSession.selectOne("findUserById",?1);
????????System.out.println(user.toString());
????????sqlSession.close();
????}
}
<select?id="findUserByName"?parameterType="String"?resultType="com.mybatisdemo.User">
????????select?*?from?t_user?where?username?like?concat('%','${value}','%')
</select>
??@Test
????public?void?findUserByNameTest()?throws??Exception?{
????????String?resource?=?"mybatis-config.xml";
????????InputStream?inputStream?=?Resources.getResourceAsStream(resource);
????????SqlSessionFactory?sqlSessionFactory?=?new?SqlSessionFactoryBuilder().build(inputStream);
????????SqlSession?sqlSession?=?sqlSessionFactory.openSession();
????????List<User>?users?=?sqlSession.selectList("findUserByName","g");
????????for?(User?user:users){
????????????System.out.println(user.toString());
????????}
????????sqlSession.close();
????????}

<insert?id="addUser"?parameterType="com.mybatisdemo.User"?>
???????insert?into?t_user(username,jobs,phone)?value?(#{username},#{jobs},#{phone})
</insert>
????@Test
????public?void?addUser()?throws?Exception?{
????????????String?resource?=?"mybatis-config.xml";
????????????InputStream?inputStream?=?Resources.getResourceAsStream(resource);
????????????SqlSessionFactory?sqlSessionFactory?=?new?SqlSessionFactoryBuilder().build(inputStream);
????????????SqlSession?sqlSession?=?sqlSessionFactory.openSession();
????????????User?user?=?new?User();
????????????user.setUsername("beiluo");
????????????user.setJobs("DevOps");
????????????user.setPhone("1314566666");
????????????int?rows?=?sqlSession.insert("addUser",user);
????????????if?(rows?>0){
????????????????System.out.println("Success?add?"+?rows?+"data!");
????????????}else{
????????????????System.out.println("add?data?fail!");
????????????}
????????????sqlSession.commit();
????????????sqlSession.close();
????????}

?<update?id="updateUserInfo"?parameterType="com.mybatisdemo.User">
????????update?t_user?set?username=#{username},jobs=#{jobs},phone=#{phone}?where?id?=#{id}
</update>
?@Test
????public?void?updateUserinfo()?throws??Exception?{
????????String?resource?=?"mybatis-config.xml";
????????InputStream?inputStream?=?Resources.getResourceAsStream(resource);
????????SqlSessionFactory?sqlSessionFactory?=?new?SqlSessionFactoryBuilder().build(inputStream);
????????SqlSession?sqlSession?=?sqlSessionFactory.openSession();
????????User?user?=?new?User();
????????user.setId(1);
????????user.setUsername("jike");
????????user.setJobs("qa");
????????user.setPhone("13142764432");
????????int?rows?=?sqlSession.update("updateUserInfo",user);
????????if?(rows?>0){
????????????System.out.println("Success?update?"+?rows?+" data!");
????????}else{
????????????System.out.println("update?data?fail!");
????????}
????????sqlSession.commit();
????????sqlSession.close();
????}

?<delete?id="deleteUser"?parameterType="com.mybatisdemo.User"?>
????????delete?from?t_user?where?id=#{id}
</delete>
@Test
????public?void?deleteUser()?throws?Exception?{
????????String?resource?=?"mybatis-config.xml";
????????InputStream?inputStream?=?Resources.getResourceAsStream(resource);
????????SqlSessionFactory?sqlSessionFactory?=?new?SqlSessionFactoryBuilder().build(inputStream);
????????SqlSession?sqlSession?=?sqlSessionFactory.openSession();
????????int?rows?=?sqlSession.delete("deleteUser",1);
????????if?(rows?>0){
????????????System.out.println("Success?delete?"+?rows?+" data!");
????????}else{
????????????System.out.println("delete?data?fail!");
????????}
????????sqlSession.commit();
????????sqlSession.close();
????}



更多精彩推荐
?拿下 Gartner 容器产品第一,阿里云打赢云原生关键一战!
?斩获GitHub 2000+ Star,阿里云开源的 Alink 机器学习平台如何跑赢双11数据“博弈”?| AI 技术生态论
?微软为一人收购一公司?破解索尼程序、写黑客小说,看他彪悍的程序人生!
?IBM、微软、苹果、谷歌、三星……这些区块链中的科技巨头原来已经做了这么多事!
?资深程序员总结:分析Linux进程的6个方法,我全都告诉你
点击阅读原文,精彩继续!
关注公众号:拾黑(shiheibook)了解更多
[广告]赞助链接:
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
关注网络尖刀微信公众号随时掌握互联网精彩
赞助链接
排名
热点
搜索指数
- 1 2025年中国经济如何“顶压前行” 7904523
- 2 人民币现金收付新规发布 7808378
- 3 河南学校13死4伤火灾案宣判 7714249
- 4 海南助力企业“买全球卖全球” 7617226
- 5 普京承认自己正在恋爱中 7524338
- 6 海南封关首日1.5吨榴莲1小时被抢空 7424300
- 7 台北攻击事件已致4死5伤:嫌犯坠亡 7331432
- 8 飞天茅台价格暴跌 黄牛损失惨重 7233848
- 9 城乡居民养老金将迎第八次上涨 7142836
- 10 俄罗斯将对日本采取反制措施 7045963







CSDN
