Mybatis learning notes-02 (in update)
1. Add operation
1.1 add insertUser() method in UserMapper interface
public interface UserMapper {
List<User> listAllUsers();
int insertUser(User user);
}
1.2 configure add operation in Mapper mapping file 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="cn.ykf.mapper.UserMapper">
<select id="listAllUsers" resultType="cn.ykf.pojo.User">
SELECT * FROM user
</select>
<insert id="insertUser" parameterType="cn.ykf.pojo.User">
INSERT INTO user(username,birthday,sex,address) VALUES (#{username},#{birthday},#{sex},#{address})
</insert>
</mapper>
- Reminder
- When writing a mapping file, you can first write a SQL statement that can run normally on the MySQL client, then move it to the mapping file, and replace the original actual parameters with the parameter symbols of Mybatis
- parameterType represents the fully qualified name or alias of the parameter class that will be passed into the statement.
-
The parameter symbols {username}, {birthday}, {birthday}, {sex}, and {address} must correspond to each attribute name of the User class one by one, and cannot be scribbled.
- The property name is the XX part of getXxx()/setXxx(), which is the member variable name in most cases, but not the member variable name in a few cases, that is to say, the member variable and the property cannot be the same.
- For descriptions of configuration files, you can view the official website documents: XML Mapping file for Mybatis
1.3 test add operation
public class MybatisTest {
private InputStream is;
private SqlSession sqlSession;
private UserMapper mapper;
@Before
public void init() throws Exception {
is = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(is);
sqlSession = factory.openSession();
mapper = sqlSession.getMapper(UserMapper.class);
}
@After
public void destory() throws Exception {
sqlSession.commit();
sqlSession.close();
is.close();
}
@Test
public void testInsertUser() {
User user = new User();
user.setUsername("Fish meal");
user.setBirthday(new Date());
user.setSex("male");
user.setAddress("Guangdong");
int count = mapper.insertUser(user);
System.out.println("Add the number of : " + count);
}
}
- It should be noted that if the transaction is not committed through sqlSession.commit(); in the destory() method, the added record will not be written to the database.
-
Because we did not set the transaction auto commit when we called openSession(), the final transaction will automatically roll back, resulting in the record not being written to the database. See below
-
The overload method of openSession() is shown in the figure below. Therefore, if you need to automatically commit a transaction, you only need factory.openSession(true); to do so.
1.4 test results
data:image/s3,"s3://crabby-images/bddd6/bddd6ef22b5518c24d03bc91269a3f85d6e0715a" alt=""
2. Delete
2.1 add the deleteUserById() method in the UserMapper interface
int deleteUserById(Integer userId);
2.2 configure deletion in Mapper mapping file UserMapper.xml
<delete id="deleteUserById" parameterType="java.lang.Integer">
DELETE FROM user WHERE id = #{uid}
</delete>
- Here are two points to pay attention to!
- First, if the parameter is a wrapper class of basic type or basic type, and there is only one parameter, the parameter symbol can be written at will. That is, although the method in the Mapper interface is declared as int deleteUserById(Integer userId), you can write {userId} or {aaaa} in the mapping file.
- Second, parameterType can write int, int, integer, integer and java.lang.Integer.
2.3 test deletion
@Test
public void testDeleteUserById(){
int count = mapper.deleteUserById(50);
System.out.println("The number of deleted items is: " + count);
}
2.4 test results
data:image/s3,"s3://crabby-images/10a81/10a818c69a3db7cabbab5b7c5eaef0d85fd7d01b" alt=""
3. Modify
3.1 add the updateUser method in the UserMapper interface
int updateUser(User user);
3.2 configure modification in Mapper mapping file UserMapper.xml
<update id="updateUser" parameterType="cn.ykf.pojo.User">
UPDATE user SET username = #{username}, birthday = #{birthday}, sex = #{sex}, address = #{address} WHERE id = #{id}
</update>
3.3 test modification
@Test
public void testUpdateUser() {
User user = new User();
user.setUsername("update");
user.setAddress("test");
user.setSex("female");
user.setBirthday(new Date());
user.setId(49);
int count = mapper.updateUser(user);
System.out.println("The number of modifications is: " + count);
}
3.4 test results
data:image/s3,"s3://crabby-images/1f161/1f161a80e8effa30ef071d6dedc145fe7e529305" alt=""
Published 4 original articles, won praise 2, visited 104
Keywords:
xml
Mybatis
Database
Java
Added by matchu on Wed, 29 Jan 2020 06:37:13 +0200