Mybatis增删改查基本操作

一、XML实现方式

1、mapper.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.xml中出现重复的id -->
<mapper namespace="com.mybatis.mapper.UserMapper">
<!-- 新增用户数据 -->
<insert id="insertUser" parameterType="com.mybatis.model.User">
<!-- #{name}相当于jdbc中的的?号,name值与Bean字段对应,可自动获取 -->
insert into users values(#{id}, #{username}, #{password}, #{email}, #{age})
</insert> <!-- 查找用户数据 -->
<select id="selectUser" resultType="com.mybatis.model.User" parameterType="int">
select * from users where id = #{id}
</select> <!-- 查找用户数据集合 -->
<!-- 基本数据类型可以不用写完整类名 -->
<select id="selectUsers" resultType="com.mybatis.model.User" parameterType="int">
select * from users t where t.age = #{age}
</select> <!-- 更新用户数据 -->
<update id="updateUser" parameterType="com.mybatis.model.User">
update users set age = #{age} where id = #{id}
</update> <!-- 删除用户数据 -->
<delete id="deleteUser" parameterType="int">
delete from users where id = #{id}
</delete>
</mapper>
2、单元测试代码
/**
* 使用XML配置实现CRUD操作
*/
public class DbTest2 { private SqlSessionFactory sqlSessionFactory;
/**
* 初始化工作
*/
@Before
public void init() throws IOException {
//通过mybatis提供的资源加载类加载配置文件
Reader reader = Resources.getResourceAsReader("Configuration.xml");
//获取SqlSessionFactoryBuilder
SqlSessionFactoryBuilder sqlSessionFactroyBuilder = new SqlSessionFactoryBuilder();
//根据XML配置文件构建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = sqlSessionFactroyBuilder.build(reader);
this.sqlSessionFactory = sqlSessionFactory;
} //新增操作
@Test
public void insertUser() {
//Mybatis默认情况下不会commit,即默认connection.setAutoCommit(false);
//传入true代表自动提交
SqlSession session = sqlSessionFactory.openSession(true);
try {
User user = new User();
user.setId("1");
user.setUsername("zhangsan");
user.setPassword("123456");
user.setAge("18");
user.setEmail("zhangsan@163.com");
session.insert("com.mybatis.mapper.UserMapper.insertUser", user);
} finally {
session.close();
}
} //查询操作
@Test
public void queryUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
User user = session.selectOne("com.mybatis.mapper.UserMapper.selectUser", 1);
System.out.println(user);
} finally {
session.close();
}
} //查询多条操作
@Test
public void queryUsers() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
List<User> userList = session.selectList("com.mybatis.mapper.UserMapper.selectUsers", 18);
System.out.println(userList.size());
} finally {
session.close();
}
} //更新操作
@Test
public void updateUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
User user = new User();
user.setId("1");
user.setAge("25");
int num = session.update("com.mybatis.mapper.UserMapper.updateUser", user);
System.out.println(num);
} finally {
session.close();
}
} //删除操作
@Test
public void deleteUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
int num = session.delete("com.mybatis.mapper.UserMapper.deleteUser", 1);
System.out.println(num);
} finally {
session.close();
}
}
}

二、注解实现

1、编写Mapper接口
* 使用注解的方式配置SQL映射关系
* 需要注意的事此接口不用具体编写实现代码,而将由Mybatis动态的帮我们构建
* 这样的代码由于避免了强制类型转换和参数不匹配的问题,因此更加安全
*/
public interface UserMapperI {
@Insert("insert into users values(#{id}, #{username}, #{password}, #{email}, #{age})")
int insertUser(User user); @Select("select * from users where id = #{id}")
User selectUser(String id); @Select("select * from users t where t.age = #{age}")
List<User> selectUsers(String age); @Update("update users set age = #{age} where id = #{id}")
int updateUser(User user); @Delete("delete from users where id = #{id}")
int deleteUser(String id);
}
2、注册接口
<?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="database.properties"></properties> <environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!-- 注册sql映射文件 --> <mappers>
<!-- 注册UserMapper.xml文件 -->
<mapper resource="com/mybatis/mapper/UserMapper.xml"/>
<!-- 注册UserMapperI接口 -->
<mapper class="com.mybatis.mapper.UserMapperI"/>
</mappers>
</configuration>
3、单元测试代码
/**
* 使用注解实现CRUD操作
*/
public class DbTest3 {
private SqlSessionFactory sqlSessionFactory;
@Before
public void init() throws IOException {
//通过mybatis提供的资源加载类加载配置文件
Reader reader = Resources.getResourceAsReader("Configuration.xml");
//获取SqlSessionFactoryBuilder
SqlSessionFactoryBuilder sqlSessionFactroyBuilder = new SqlSessionFactoryBuilder();
//根据XML配置文件构建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = sqlSessionFactroyBuilder.build(reader);
this.sqlSessionFactory = sqlSessionFactory;
} //新增操作
@Test
public void insertUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
UserMapperI mapper = session.getMapper(UserMapperI.class);
User user = new User();
user.setId("1");
user.setUsername("zhangsan");
user.setPassword("123456");
user.setAge("18");
user.setEmail("zhangsan@163.com");
int num = mapper.insertUser(user);
System.out.println(num);
} finally {
session.close();
}
} //查询操作
@Test
public void queryUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
UserMapperI mapper = session.getMapper(UserMapperI.class);
User user = mapper.selectUser("1");
System.out.println(user);
} finally {
session.close();
}
} //查询多条操作
@Test
public void queryUsers() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
UserMapperI mapper = session.getMapper(UserMapperI.class);
List<User> userList = mapper.selectUsers("18");
System.out.println(userList.size());
} finally {
session.close();
}
} //更新操作
@Test
public void updateUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
UserMapperI mapper = session.getMapper(UserMapperI.class);
User user = new User();
user.setId("1");
user.setAge("25");
int num = mapper.updateUser(user);
System.out.println(num);
} finally {
session.close();
}
} //删除操作
@Test
public void deleteUser() {
SqlSession session = sqlSessionFactory.openSession(true);
try {
UserMapperI mapper = session.getMapper(UserMapperI.class);
int num = mapper.deleteUser("1");
System.out.println(num);
} finally {
session.close();
}
}
}

Mybatis入门(二)------增删改查的更多相关文章

  1. mybatis入门(二):增删改查

    mybatis的原理: 1.mybatis是一个持久层框架,是apache下的顶级项目 mybatis托管到googlecode下,目前托管到了github下面 2.mybatis可以将向prepar ...

  2. mybatis入门二-----增删改查

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  3. Mybatis入门之增删改查

    Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...

  4. MyBatis入门2_增删改查+数据库字段和实体字段不一致情况

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! 当数据库字段和实体bean中属性不一致时 之前数据库P ...

  5. MyBatis入门案例 增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

  6. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  7. MyBatis简单的增删改查以及简单的分页查询实现

    MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...

  8. MyBatis -- 对表进行增删改查(基于注解的实现)

    1.MyBatis对数据库表进行增/删/改/查 前一篇使用基于XML的方式实现对数据库的增/删/改/查 以下我们来看怎么使用注解的方式实现对数据库表的增/删/改/查 1.1  首先须要定义映射sql的 ...

  9. Spring Boot 使用Mybatis注解开发增删改查

    使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...

  10. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

随机推荐

  1. 选择排序的实现以及如何编写测试 #CS61B-sp18-3.1

    Selection Sort的思想: 就是在一系列数字中先找到一个最小的放在所有数字的第一个位置上,然后再从余下的数字里面找最小个放在余下的数字里的第一个位置上. 例如: 在这段数据里面我们找到最小的 ...

  2. 算数组的长度cpp

    今天被自己整傻了.... cpp  int 型的数组就别想用strlen来求长度了,会报错的. (当然java 里直接用length就可以了...) 所以我建议用vector!!!!!!

  3. 那些年拿过的shell之springboot jolokia rce

    日穿扫描扫到一个spring boot actuator 可以看到有jolokia这个端点,再看下jolokia/list,存在type=MBeanFactory 关键字 可以使用jolokia-re ...

  4. Python爆火的原因与未来|内附Python学习书籍大礼包无偿领取|

    从12年到20年,python以肉眼可见的趋势超过了java,成为了当今It界人人皆知的编程语言. python为什么这么火? 网络编程语言搜索指数 适合初学者 Python具有语法简单.语句清晰的特 ...

  5. [转]Tomcat 调优的技巧

    原文地址:https://mp.weixin.qq.com/s/7_bz3OPoH3x7xkkwkhJhbw Tomcat调优这块,在面试中会经常问道.目前Tomcat调优主要分为2大类,当前解释用的 ...

  6. win10 64位 汇编环境

    masm6或者masm5 下载. dosbox 下载安装 为何要用这个呢,因为 机子是64位的,dosbox 模拟32位的用来执行生成的exe文件 masm 安装好后,有个bin文件:个人建议将其设置 ...

  7. 记一次LayUI中Table动态添加列数据

    这次在开发中遇到,有列数不固定的情况.废话不多说,先上图,在上代码. 下面上JS代码 function SearchData() { var dYear = $("#DYear") ...

  8. C语言学习笔记之switch有无break差别

    今天复习到了switch语句,我们正常的写法中,是经常把switch和break搭配在一起的 当我们把break去掉呢 可以看到,我们选择2时,的确会到case 2里面执行语句,可是没有break还是 ...

  9. 14、Java文件操作stream、File、IO

    1.文件操作涉及到的基本概念 File File类 是文件操作的主要对象中文意义就是 文件 顾名思意 万物皆文件,在计算上看到的所有东西都是文件保存,不管是你的图片.视频.数据库数据等等都是按照基本的 ...

  10. java_内部类、匿名内部类的使用

    内部类 将一个类A定义在另一个类B里面,里面的那个类A就称为内部类,B则称为外部类. 内部类的分类 成员内部类,类定义在了成员位置 (类中方法外称为成员位置) 局部内部类,类定义在方法内 成员内部类 ...