Mybatis-02 CRUD
CRUD
先來簡單回顧一下之前的準備步驟:
- 建立一個
資料庫
,並加入資料 - 建立一個
Maven
專案 - 匯入對應的
依賴
- 建立
Pojo
類和Dao
類 - 寫出
Mybatis
工具類 - 配置
mybatis.xml
完成以上步驟之後,就可以進行測試了。
具體可以檢視本部落格文章:Mybatis-01
1.select
查詢
操作
1.1 Dao類
public interface UserDao {
//通過id查user
public List<user> getUserByID(int id);
}
<?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="com.Dao.UserDao">
<select id="getUserByID" resultType="pojo.user" parameterType="int">
select * from mybatis.user where id=#{id}
</select>
</mapper>
1.2 測試
public class Test {
@org.junit.Test
public void test(){
//第一步:獲得SqlSession物件
SqlSession sqlSession = mybatis_util.getSqlSession();
//執行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
List<user> userList = mapper.getUserByID(1); //查詢id=1的user
for (user user : userList) {
System.out.println(user);
}
//關閉SqlSession
sqlSession.close();
}
}
檢視id=1
的user:
2.Insert
插入
操作
2.1 Dao類
public interface UserDao {
public int insertuser(user user);
}
<?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="com.Dao.UserDao">
<insert id="insertuser" parameterType="pojo.user">
insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd})
</insert>
</mapper>
2.2 測試
public class Test {
@org.junit.Test
public void test(){
//第一步:獲得SqlSession物件
SqlSession sqlSession = mybatis_util.getSqlSession();
//執行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
user user1 = new user(4, "李", "1456");
int i = mapper.insertuser(user1);
System.out.println(i);
sqlSession.commit(); //不同於查詢 增刪改都需要提交事務
List<user> userList = mapper.getUserList();
for (user user : userList) {
System.out.println(user);
}
//關閉SqlSession
sqlSession.close();
}
}
建立一個新user
,id:1、name:李、pwd:1456,通過sql操作,加入資料庫。
i
輸出1
,說明成功。
最後輸出全部,檢視資料庫中全部user
。
3.delete
3.1 Dao類
public interface UserDao {
public int deluser(int id);
}
<?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="com.Dao.UserDao">
<delete id="deluser" parameterType="int">
delete from mybatis.user where id = #{id}
</delete>
</mapper>
3.2測試
public class Test {
@org.junit.Test
public void test(){
//第一步:獲得SqlSession物件
SqlSession sqlSession = mybatis_util.getSqlSession();
//執行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
int i = mapper.deluser(2);
System.out.println(i);
sqlSession.commit(); //不同於查詢 增刪改都需要提交事務
List<user> userList = mapper.getUserList();
for (user user : userList) {
System.out.println(user);
}
//關閉SqlSession
sqlSession.close();
}
}
刪除id=2
的user。
i
輸出1
,說明成功。
最後輸出全部,檢視資料庫中全部user
。
4.update
4.1 Dao類
public interface UserDao {
public int updateuser(user user);
}
<?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="com.Dao.UserDao">
<update id="updateuser" parameterType="pojo.user">
update mybatis.user set name = #{name},pwd=#{pwd} where id = #{id}
</update>
</mapper>
4.2測試
public class Test {
@org.junit.Test
public void test(){
//第一步:獲得SqlSession物件
SqlSession sqlSession = mybatis_util.getSqlSession();
//執行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
user user1 = new user(4, "李1", "145600");
int i = mapper.updateuser(user1);
System.out.println(i);
sqlSession.commit();
List<user> userList = mapper.getUserList();
for (user user : userList) {
System.out.println(user);
}
//關閉SqlSession
sqlSession.close();
}
}
更新id=4
的user。
i
輸出1
,說明成功。
最後輸出全部,檢視資料庫中全部user
。
5.注意事項
標籤
不要匹配錯誤,對應的id
、parameterType
、resultType
不可以錯誤- resource中的
mybatis配置檔案
一定要繫結mapper
- 程式配置檔案必須
符合規範
- 依賴沒有成功加入,可以
手動加入
資原始檔
未開啟,配置檔案中加入<build></build>
內容
萬能Map
實體類,或者資料庫中的表,欄位或者引數過多,我們應當考慮使用Map
即:parameterType="map"
insert
操作進行舉例:
1.Dao類
public interface UserDao {
public int insertuser(Map<String,Object> map);
}
<?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="com.Dao.UserDao">
<insert id="insertuser" parameterType="map">
insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd})
</insert>
</mapper>
2.測試
public class Test {
@org.junit.Test
public void test(){
//第一步:獲得SqlSession物件
SqlSession sqlSession = mybatis_util.getSqlSession();
//執行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("id",5);
map.put("name","map");
map.put("pwd","1111");
int i = mapper.insertuser(map);
System.out.println(i);
sqlSession.commit();
List<user> userList = mapper.getUserList();
for (user user : userList) {
System.out.println(user);
}
//關閉SqlSession
sqlSession.close();
}
}
建立一個Map
,在其中加入對應的資料
,通過sql操作,加入資料庫。
i
輸出1
,說明成功。
最後輸出全部,檢視資料庫中全部user
。
模糊查詢
在此,不進行具體操作,再次舉例兩中方式:
1.傳值時加入%
該功能只是更改sql語句
,並在傳值時加入%
即可。
sql語句:
<select id="getUserByID" resultType="pojo.user" parameterType="string">
select * from mybatis.user where name like #{name}
</select>
Test類:
List<user> userList = mapper.getUserByName("%張%");
2.sql語句時加入%
該功能只是更改sql語句
,在語句中加入%
,並正常傳值時即可。
sql語句:
<select id="getUserByID" resultType="pojo.user" parameterType="string">
select * from mybatis.user where name like "%"#{name}"%"
</select>
Test類:
List<user> userList = mapper.getUserByName("張");
上述兩種操作,都可以查出對姓名中含有張
的進行查詢。
%
的不同含義:
- %abc 表示以
abc結尾
的所有字串; - abc% 表示以
abc 開頭
的所有字串; - %abc% 表示
所有包含abc
的字串;
個人部落格為:
MoYu's Github Blog
MoYu's Gitee Blog