步骤一: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操作的更多相关文章

  1. 【Mybatis】MyBatis对表执行CRUD操作(三)

    本例在[Mybatis]MyBatis配置文件的使用(二)基础上继续学习对表执行CRUD操作 使用MyBatis对表执行CRUD操作 1.定义sql映射xml文件(EmployeeMapper.xml ...

  2. 使用MyBatis对表执行CRUD操作

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

  3. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  4. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  5. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

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

  6. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  7. mybatis(二)执行CRUD操作的两种方式配置和注解

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

  8. MyBatis学习总结_02_使用MyBatis对表执行CRUD操作

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

  9. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

随机推荐

  1. RabbitMQ 应用二

    在应用一中,基本的消息队列使用已经完成了,在实际项目中,一定会出现各种各样的需求和问题,RabbitMQ内置的很多强大机制和功能会帮助我们解决很多的问题,下面就一个一个的一起学习一下. 消息响应机制 ...

  2. 我对xss以及sql的理解

    我对xss以及sql的理解 本文作者:情殇(查看作者所有博文) 作者邮箱:3135117931@qq.com 发布时间: Fri, 12 Jul 2019 19:16:00 +0800 Xss和sql ...

  3. iOS 毛玻璃效果的实现方法

    iOS开发中有的时候需要将图片设置模糊,来实现特定的效果获取更好的用户体验, iOS7之后半透明模糊效果得到大范围使用的比较大,现在也可以看到很多应用局部用到了图片模糊效果,可以通过高斯模糊和毛玻璃效 ...

  4. 在iframe内页触发顶层页面body的blur事件

    //在iframe内页触发顶层页面body的blur事件. if (window != top) { $(document.body).click(function () { $(top.docume ...

  5. 解决 google 浏览器记住密码导致输入框样式改变(变成淡黄色背景)

    直接在页面上使用css代码: input:-webkit-autofill , textarea:-webkit-autofill, select:-webkit-autofill { -webkit ...

  6. Axure总结

    https://blog.csdn.net/xlegendxblog/article/details/54378705 1.常用符号 2.箭头的绘制 3.绘制流程图基本要点:流程路径不要交叉 4.对复 ...

  7. Nginx跨域访问场景配置和防盗链

    跨域访问控制 跨域访问 为什么浏览器禁止跨域访问 不安全,容易出现CSRF攻击! 如果黑客控制的网站B在响应头里添加了让客户端去访问网站A的恶意信息,就会出现CSRF攻击 Nginx如何配置跨域访问 ...

  8. 详解介绍Selenium常用API的使用--Java语言(完整版)

    参考:http://www.testclass.net/selenium_java/ 一共分为二十个部分:环境安装之Java.环境安装之IntelliJ IDEA.环境安装之selenium.sele ...

  9. vue框架之脚手架(vue-cli)的使用

    前期准备 1.在使用之前需要安装node.js,https://nodejs.org/dist/latest-v8.x/ 2.下载之后在cmd中测试 node -v npm -v 如图上即可 3.下载 ...

  10. Linux网络编程综合运用之MiniFtp实现(九)

    上次中实现了FTP命令的映射来避免很多if....else的判断,这次主要是开始实现目录列表的传输,先看一下目前实现的: 数据连接创建好之后则开始进行目录列表的传输了,而要传输目录列表,首先要将目录列 ...