Mybatis基础-完整CRUD操作
步骤一:mybatis基本配置
1)创建Java项目,在lib下导入mybatis所需要的Jar包,包括链接mysql的mysql-connector-java-5.1.7-bin.jar。
2)在src目录下新建一个mybatis的配置文件
mybatis_conf.xml的内容如下
<?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>
<properties resource="db.properties"></properties> <!-- 启用别名 -->
<typeAliases>
<package name="com.feng.domain" />
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driverClass}" />
<property name="url" value="${jdbc.jdbcUrl}" />
<property name="username" value="${jdbc.user}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>
<!-- 配置 自动扫描 包下的 sql映射文件-->
<mappers>
<package name="com.feng.dao" />
</mappers>
</configuration>
db.properties
jdbc.user = root
jdbc.password=123456
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql://127.0.0.1:3306/mybatis0814?useUnicode=true&characterEncoding=utf-8
步骤二:
1)新建表t_user,因为Mybatis不会自动创建数据表,和hibernate不一样,只专注sql

2)定义表的实体类,必须一一对应,否则需要在映射里面设置resultMap结果集映射
User
package com.feng.domain; import java.util.Date; public class User
{
// 和表中的字段一一对应,否则需要在对应的Mapper配置文件用到resultMap结果集映射。
private Integer id;
private String username;
private int age;
private Date registerDate; public User(){} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public Date getRegisterDate() {
return registerDate;
} public void setRegisterDate(Date registerDate) {
this.registerDate = registerDate;
} @Override
public String toString() {
return "User [id=" + id + ", username=" + username + ", age=" + age
+ ", registerDate=" + registerDate + "]";
}
3)在dao的包下,新建sql映射配置xml
UserMapper.xml 必须和实体类对应 格式:实体类+Mapper ,否则自动扫描不出来
<?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">
<!-- 完整namespace,取包名+映射文件 -->
<mapper namespace="com.feng.dao.UserMapper">
<!-- 对应的id为映射接口的方法 ,parameterType 设置为入参的类型,因为我在配置文件中启用了别名,自动扫描domain包,所以不需要写包名,如果没有就是com.feng.domain.User
resultType就是返回的结果集类型,如果是基本类型,mybaits已经封装好了,直接写类型就好;如果是实体类,就要写上实体类的类型,也是可以别名的。
useGeneratedKeys="true" keyProperty="id" :启用这段后,可以得到新增的数据的主键id
#{}里面新增的实体属性值,用#{},也可以用${value};推荐用#{},因为会自动使用parperstatement,防止sql注入
-->
<insert id="addUser" parameterType="User" useGeneratedKeys="true" keyProperty="id">
insert into t_user(username,age,registerDate)
values(#{username},#{age},#{registerDate})
</insert>
<delete id = "deleteUser" parameterType="Integer" >
delete from t_user where id = #{id}
</delete>
<update id = "updateUser" parameterType="User" >
update t_user
set
username = #{username},age=#{age},registerDate=#{registerDate}
where
id = #{id}
</update>
<!-- 多个数据 和 单个 数据 ,他们的类型都是一样,都是User -->
<select id = "getUserById" parameterType="Integer" resultType = "User">
select * from t_user where id = #{id}
</select>
<select id = "getAllUser" resultType="User">
select * from t_user
</select>
<select id = "getAllUser1" parameterType="map" resultType="User">
select * from t_user where age > #{age} and username = #{username}
</select>
</mapper>
这里注意一点,update、delete 返回值是:更新或删除的行数;无需指明resultClass;但如果有约束异常而删除失败,只能去捕捉异常。
insert,返回值是:新插入行的主键(primary key);需要包含<selectKey>语句,才会返回主键,否则返回值为null。
4)操作接口
UserMapper.java
package com.feng.dao; import java.util.List;
import java.util.Map; import com.feng.domain.User; public interface UserMapper
{
//增加一个用户
public void addUser(User user); //删除一个用户
public void deleteUser(Integer id); //修改用户信息
public void updateUser(User user); //得到一个用户
public User getUserById(Integer id); //得到所有用户
public List<User> getAllUser(); // 多入参情况下用map
public List<User> getAllUser1(Map<String, Object> map); }
步骤三
1)新建测试类Test_Crud.java
package com.feng.test; import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.HashMap; 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.Before;
import org.junit.Test; import com.feng.domain.User; public class Test_Crud { private SqlSessionFactory sqlSessionFactory = null; @Before
public void init() throws IOException {
// 使用MyBatis提供的Resources类加载mybatis的配置文件(它也加载关联的映射文件)
InputStream inputStream = Resources
.getResourceAsStream("mybatis_conf.xml");
// 创建SqlSessionFactory工厂
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} @Test
public void addUser() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try { sqlSession = sqlSessionFactory.openSession();
User user = new User();
user.setAge(22);
user.setRegisterDate(new Date());
user.setUsername("feng");
sqlSession.insert("com.feng.dao.UserMapper.addUser", user);
sqlSession.commit();
System.out.println(user.getId()); } catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} @Test
public void deleteUser() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try { sqlSession = sqlSessionFactory.openSession();
sqlSession.delete("com.feng.dao.UserMapper.deleteUser", 2);
sqlSession.commit(); } catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} @Test
public void updateUser() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try { sqlSession = sqlSessionFactory.openSession();
User user = new User();
user.setAge(22);
user.setId(1);
user.setRegisterDate(new Date());
user.setUsername("wei");
sqlSession.update("com.feng.dao.UserMapper.updateUser", user);
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} @Test
public void getUserById() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try {
sqlSession = sqlSessionFactory.openSession(); User user = sqlSession.selectOne(
"com.feng.dao.UserMapper.getUserById", 1);
System.out.println(user.toString());
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} @Test
public void getAllUser() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try {
sqlSession = sqlSessionFactory.openSession(); java.util.List<User> list = sqlSession
.selectList("com.feng.dao.UserMapper.getAllUser");
for (User user : list) {
System.out.println(user.toString());
}
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} @Test
// 多入参情况下,用map
public void getAllUser1() {
// 创建并且打开sqlsession
SqlSession sqlSession = null;
try {
sqlSession = sqlSessionFactory.openSession();
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("age", 20);
map.put("username", "feng"); java.util.List<User> list = sqlSession.selectList(
"com.feng.dao.UserMapper.getAllUser1", map);
for (User user : list) {
System.out.println(user.toString());
}
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
} }
最后的结构图如下

Mybatis基础-完整CRUD操作的更多相关文章
- 【Mybatis】MyBatis对表执行CRUD操作(三)
本例在[Mybatis]MyBatis配置文件的使用(二)基础上继续学习对表执行CRUD操作 使用MyBatis对表执行CRUD操作 1.定义sql映射xml文件(EmployeeMapper.xml ...
- 使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)
本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...
- MyBatis入门学习教程-使用MyBatis对表执行CRUD操作
上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
- mybatis(二)执行CRUD操作的两种方式配置和注解
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...
- MyBatis学习总结_02_使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...
- 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
[转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...
随机推荐
- 为Visual Studio安装其他控件(cognex 康耐视)时报错:未能加载文件或程序集 EnvDTE, Version=8.0.0.0
解决办法: 在VS的路径下(一般为:C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Private ...
- 效率提升工具Listary
效率提升工具Listary https://baijiahao.baidu.com/s?id=1590032175308204846&wfr=spider&for=pc
- webdispatch配置
PRDPISP01:/sapmnt/WIP/profile # su - wipadm PRDPISP01:wipadm 23> cdpro PRDPISP01:wipadm 24> ls ...
- Eclipse 交叉编译环境
创建空工程 添加交叉编译环境 添加工程文件 如需修改交叉编译环境 Cross GCC:使用交叉编译命令编译,需要自己指定 MinGW GCC:使用make命令编译,需要有Makefile Make T ...
- 【前端适配】vw单位移动端适配方案
近些年移动端的强势崛起,导致移动端适配越来越重要,个人之前一直使用的是rem进行适配,但是发现并不是非常完美,给力的是大漠老师写了一篇<如何在Vue项目中使用vw实现移动端适配>,比较完美 ...
- java中级面试题
1.Java中堆和栈有什么不同? 每个线程都有自己的栈内存,用于存储本地变量,方法参数和栈调用,一个线程中存储的变量对其它线程是不可见的.而堆是所有线程共享的一片公用内存区域.对象都在堆里创建,为了提 ...
- Vue指令之`v-bind`的三种用法及v-on事件指令
v-bind:是 Vue中,提供的用于绑定属性的指令 1. 直接使用指令`v-bind` 2. 使用简化指令`:` 3. 在绑定的时候,拼接绑定内容:`:title="btnTitle + ...
- 前端框架开始学习Vue(二)
1 根据关键字实现数组的过滤 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...
- GitHub开源的10个超棒后台管理面板
目录1.AdminLTE 2.vue-Element-Admin 3.tabler 4.Gentelella 5.ng2-admin 6.ant-design-pro 7.blur-admin 8.i ...
- kubeadm init初始化报错解决,亲测
[preflight] You can also perform this action in beforehand using 'kubeadm config images pull' error ...