MyBatis的单表的crud
-
创建maven项目,并分别添加依赖,junit,mysql,mybatis(3.4.6)
-
在resouces下创建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节点 里面有配置信息 分别是环境和映射 其中环境里有datasource,里面有我们熟悉的连接数据库的四个字符串 --> <configuration> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/hello"/> <property name="username" value="root"/> <property name="password" value="123456"/> </dataSource> </environment> </environments> <mappers> <mapper resource="com/qfedu/pojo/UserMapper.xml"/> </mappers> </configuration>
-
db.sql
CREATE TABLE `user` ( `uid` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(20) NOT NULL, `password` varchar(20) NOT NULL, `age` int(11) DEFAULT NULL, `addr` varchar(50) DEFAULT NULL, PRIMARY KEY (`uid`), UNIQUE KEY `username` (`username`) ) ENGINE=InnoDB AUTO_INCREMENT=17 DEFAULT CHARSET=latin1
-
User.java
package com.qfedu.pojo; public class User { private int uid; private String username; private String password; private int age; private String addr; @Override public String toString() { return "User{" + "uid=" + uid + ", username='" + username + '\'' + ", password='" + password + '\'' + ", age=" + age + ", addr='" + addr + '\'' + '}'; } public int getUid() { return uid; } public void setUid(int uid) { this.uid = uid; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getAddr() { return addr; } public void setAddr(String addr) { this.addr = addr; } }
-
在com.qfedu.pojo的包下创建UserMapper.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文件都将有一个自己的映射的namespace, 每个方法对应自己的sql语句,每个sql语句对应有一个id 整个项目中所有的namespace.id必须是唯一的 --> <mapper namespace="com.qfedu.pojo.UserMapper"> <select id="selectUser" resultType="com.qfedu.pojo.User"> select * from user </select> <select id="selectUserCount" resultType="int"> select count(1) from user; </select> <select id="selectUsersByPage1" resultType="com.qfedu.pojo.User"> select * from user limit 3 </select> <select id="selectUsersByPage2" resultType="com.qfedu.pojo.User"> select * from user limit #{pageSize} </select> <select id="selectUsersByPage3" resultType="com.qfedu.pojo.User"> select * from user limit #{startIndex}, #{pageSize} </select> <delete id="saveUser"> insert into user values(null, #{username}, #{password}, #{age}, #{addr}); </delete> <delete id="deleteUserByUid"> delete from user where uid = #{uid} </delete> <update id="updateUser"> update user set username= #{username}, password=#{password}, age = #{age}, addr = #{addr} where uid = #{uid}; </update> </mapper>
-
TestUser.java
package com.qfedu.test; import com.qfedu.pojo.User; 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.After; import org.junit.Before; import org.junit.Test; import java.io.IOException; import java.sql.Connection; import java.util.HashMap; import java.util.List; import java.util.Map; public class TestUser { private SqlSessionFactory sf = null; private SqlSession session = null; @Before public void setUp(){ try { sf = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis.xml")); session = sf.openSession(); } catch (IOException e) { e.printStackTrace(); } } @After public void tearDown(){ if(session != null){ session.close(); session = null; } } @Test public void testGetAllUsers(){ /** * 1. 使用mybatis的配置文件以及SqlSessionFactoryBuilder建造者模式创建SqlSessionFactory对象 * 2. 使用SqlSessionFactory对象的openSession()方法来得到一个SqlSession对象,用该对象即可完成对象的所有的crud操作 * 3. 使用SqlSession对象来完成crud操作 * 4. 关闭资源 * */ /** * session的crud方法("namespace.id");整个项目中的namespace.id必须唯一 */ List<User> users = session.selectList("com.qfedu.pojo.UserMapper.selectUser"); for (User u : users) { System.out.println(u); } } @Test public void testGetAllUsersCount(){ /** * 1. 使用mybatis的配置文件以及SqlSessionFactoryBuilder建造者模式创建SqlSessionFactory对象 * 2. 使用SqlSessionFactory对象的openSession()方法来得到一个SqlSession对象,用该对象即可完成对象的所有的crud操作 * 3. 使用SqlSession对象来完成crud操作 * 4. 关闭资源 * */ /** * session的crud方法("namespace.id");整个项目中的namespace.id必须唯一 */ Integer count = session.selectOne("com.qfedu.pojo.UserMapper.selectUserCount"); System.out.println(count); } @Test public void testGetUsersByPage1(){ List<User> users = session.selectList("com.qfedu.pojo.UserMapper.selectUsersByPage1"); for (User u : users) { System.out.println(u); } } @Test public void testGetUsersByPage2(){ List<User> users = session.selectList("com.qfedu.pojo.UserMapper.selectUsersByPage2", 9); for (User u : users) { System.out.println(u); } } @Test public void testGetUsersByPage3(){ Map<String, Integer> map = new HashMap<>(); map.put("startIndex", 10); map.put("pageSize", 5); List<User> users = session.selectList("com.qfedu.pojo.UserMapper.selectUsersByPage3", map); for (User u : users) { System.out.println(u); } } @Test public void testSaveUser(){ User u = new User(); u.setUsername("lisi"); u.setPassword("888888"); u.setAddr("wuhan"); u.setAge(20); int result = session.insert("com.qfedu.pojo.UserMapper.saveUser", u); System.out.println(result); } @Test public void testDelete(){ Integer result = session.delete("com.qfedu.pojo.UserMapper.deleteUserByUid", 9); System.out.println(result); } @Test public void testUpdate(){ User user = new User(); user.setUid(8); user.setUsername("888"); user.setPassword("lisixin"); // user.setAge(20); // user.setAddr("nanjing"); int result = session.update("com.qfedu.pojo.UserMapper.updateUser", user); session.commit(); // System.out.println(result); } }
本案例要注意一些问题:
1. UserMapper的映射文件:
1. namespace和id在整个项目中,必须要保证唯一
2. namespace+id找到的是唯一的sql语句,标签可能不对应,但是不影响执行结果,但是还是需要规范各个标签
2. TestUser.java
1. 创建SqlSession对象的时候,SqlSessionFactory对象的openSession()方法不包含参数,则使用事务手动提交,做完增删改操作后,需要调用SqlSession对象的commit()方法完成事务的提交。如果openSession()方法包含有一个true,代表自动提交生效,我们做完增删改操作时候,就完成了对应的增删改功能。openSession()方法默认的提交方式为手动提交
2. 该类活用了junit的生命周期方法,每个测试方法执行之前都会调用标注有@Before注解的setUp()方法完成环境的准备工作,每个方法完成之后都自动的执行标注有@After注解的tearDown()方法完成资源的释放工作
3. SqlSession是mybatis中的核心对象,使用该对象即可完成对于所有操作的crud功能,里面有对应的方法,selectList(),查询列表(集合),selectOne()查询单个对象,insert(),delete,update()分别对应增删改功能。这三个方法的返回值均为受影响的行数
4. 每次使用完SqlSession对象之后,使用close()方法将SqlSession对象关闭,不建议关闭SqlSessionFactory对象
5. 关于传递参数
1. 传递单个值,sql语句里面的占位符可以任意写
2. 多个值,可以使用Map来传值,map中的key要与sql语句中的占位符一致
3. 对象传值,sql语句中的字段值与对象的属性名一致
4. 零散值的传递,可以使用两种方式arg0, arg1,...或者param1,param2...