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表中的数据, ...
随机推荐
- Authentication failed for "http://xxxxxx"
1.配置用户信息 git config --global user.name [username] git config --global user.email [email] 2.查询用户信息 ...
- C#判断字符串中含有多少个汉字
private void button1_Click(object sender, EventArgs e) { ArrayList itemList = new ArrayList(); CharE ...
- CentOS 6.x 配置iptables
CentOS 6.x 配置iptables 来源 https://www.cnblogs.com/chillax1314/p/7976067.html iptables -P INPUT DROP-- ...
- 总结一下几个for循环常见用法和区别
1.for循环//有人喜欢使用一个临时变量把长度缓存起来,说是数据量大时效果更好(我本人没有去验证) for(j = 0,len=arr.length; j < len; j++) { //执行 ...
- iOS 中 UIView 和 CALayer 的关系
UIView 有一个名叫 layer ,类型为 CALayer 的对象属性,它们的行为很相似,主要区别在于:CALayer 继承自 NSObject ,不能够响应事件. 这是因为 UIView 除了负 ...
- ios9 字符串与UTF-8 互相转换
在数据网路请求或其他情况下,需要将字符串转换成UTF-8编码 ios9后对其方法进行了修改 NSString *str = @"北京"; 把这个转成UTF8以前我们使用的是 NSS ...
- python之os与json&pickle模块
一.os模块 简单概述一下os模块就是与操作系统交互的一个接口 import os #os.getcwd() print(os.getcwd()) # 获取到当前工作目录 # 运行结果:E:\pyt ...
- 【OF框架】在Visual Studio中启用Docker支持,编译生成,并在容器运行项目
准备 本地已经安装Docker 一.添加Docker支持 第一步:查看本地Docker服务状态 第二步:项目添加Docker支持 第三步:选择Linux容器 第四步:点击启动 第五步:确认Docker ...
- Dotnet站点多个路由对应同一个Action的总结
需求:有些浏览器会屏蔽带有Ad字样的路径,此时需要创建多个路由指向同一个Action. 例如:原来 : http://lalalalalala.org:1506/api/advert/common ...
- Vim使用技巧(5) -- 宏的录制与使用
想象一个场景,我们怎么快速把下面的所有链接都加上双引号?可能你手速快,可以很快的加完,但是如果链接有上万个呢?你如何在十秒以内加完? 这时候就需要用到“宏”(其实除了宏vim还有其它方法加上双引号,这 ...