教我做網(wǎng)站立即優(yōu)化在哪里
目錄
前言
MyBatis的具體使用
一些小工具:MyBatisX
常見問題:
1.表中字段名和實(shí)體屬性名不一致
2.按條件查詢(單條件)時(shí)的,查詢條件怎么編寫
3.按條件查詢(多條件)
4.多條件查詢時(shí),用戶不把所有條件填完
5.單條件查詢時(shí),不知道用戶到底選了哪一個(gè)
6.添加用戶怎么寫接口和mapper.xml
7.添加信息時(shí),如果要主鍵增長呢
8.修改信息
9.刪除一行數(shù)據(jù)
10.批量刪除☆☆☆
MyBatis注解
增
刪
改
查
前言
為什么要有MyBatis呢?
當(dāng)然是因?yàn)镴DBC代碼太繁瑣啦~
上圖標(biāo)1的代碼有很多字符串,而這些是連接數(shù)據(jù)庫的四個(gè)基本信息,以后如果要將Mysql數(shù)據(jù)庫換成其他的關(guān)系型數(shù)據(jù)庫的話,這四個(gè)地方都需要修改,如果放在此處就意味著要修改我們的源代碼。
上圖標(biāo)2的代碼。如果表結(jié)構(gòu)發(fā)生變化,SQL語句就要進(jìn)行更改。這也不方便后期的維護(hù)。
操作很繁瑣
使用MyBatis就可以解決這些問題
MyBatis的具體使用
1.創(chuàng)建一個(gè)表。
2.導(dǎo)入依賴坐標(biāo)
3.在項(xiàng)目的resources 目錄下創(chuàng)建mybatis的配置文件 mybatis-config.xml?
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 配置別名 --><!-- 這樣的話,就在UserMapper中可以不用設(shè)置成這樣了 --><!-- <select id="selectAll" resultType="org.example.pojo.User">--><!-- 因?yàn)樵趍ybatis中配置了別名,所以可以不用謝前面的包名了 -->
<!-- <select id="selectAll" resultType="User">--><typeAliases><package name="org.example.pojo"/></typeAliases><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:///mybatis?useSSL=false"/><property name="username" value="root"/><property name="password" value="1234"/></dataSource></environment></environments><!-- 指定sql映射的路徑 -->
<!-- 因?yàn)樵趓esource目錄上有和src目錄下的下相同目錄,所以直接可以使用package包的方式 --><mappers>
<!-- <mapper resource="org/example/mapper/UserMapper.xml"/>--><package name="org.example.mapper"/></mappers>
</configuration>
4.創(chuàng)建實(shí)體類User
public class User {private int id;private String username;private String password;private String gender;private String addr;//省略了 setter 和 getter
}
5.在模塊的 resources 目錄下創(chuàng)建映射配置文件 UserMapper.xml
SQL語句就是在**Mapper.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="test"><select id="selectAll" resultType="com.itheima.pojo.User">select * from tb_user;</select>
</mapper>
需要滿足這樣的目錄層級
6.定義UserMapper接口代碼
public interface UserMapper {List<User> selectAll();
}
注意層級和名稱一致問題
7.定義一個(gè)測試類進(jìn)行測試
/*** Mybatis 代理開發(fā)*/
public class MyBatisDemo2 {public static void main(String[] args) throws IOException {//1. 加載mybatis的核心配置文件,獲取 SqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//2. 獲取SqlSession對象,用它來執(zhí)行sqlSqlSession sqlSession = sqlSessionFactory.openSession();//3. 執(zhí)行sql//3.1 獲取UserMapper接口的代理對象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);List<User> users = userMapper.selectAll();System.out.println(users);//4. 釋放資源sqlSession.close();}
}
一些小工具:MyBatisX
MyBatisX 插件
-
XML映射配置文件 和 接口方法 間相互跳轉(zhuǎn)
-
根據(jù)接口方法生成 statement
如下圖操作就可以完成,生成Mapper.xml文件中的statement
常見問題:
1.表中字段名和實(shí)體屬性名不一致
使用Mybatis時(shí),可能會(huì)出現(xiàn)數(shù)據(jù)庫表的字段名稱和實(shí)體類的屬性名稱不一樣的問題,這樣的話就不能自動(dòng)封裝數(shù)據(jù)了。
可以resultMap
具體來說:就是在 **Mapper.xml中添加下圖紅框框住的<resultMap></resultMap>部分,對字段進(jìn)行映射,下圖中前面的字段是數(shù)據(jù)庫中的命名,后面是實(shí)體類的屬性名。
然后將resultType換成resultMap
2.按條件查詢(單條件)時(shí)的,查詢條件怎么編寫
在 **Mapper中這樣寫,如下圖查詢條件是id? 就這樣寫#{id}
對于有參數(shù)的Mapper接口方法
3.按條件查詢(多條件)
可以使用以下三種方法
mapper.xml的編寫
在測試類中的調(diào)用
4.多條件查詢時(shí),用戶不把所有條件填完
這個(gè)時(shí)候就要使用到動(dòng)態(tài)SQL
使用<where></where>標(biāo)簽 和 <if></if>標(biāo)簽
5.單條件查詢時(shí),不知道用戶到底選了哪一個(gè)
這種需求需要使用到 choose(when,otherwise)標(biāo)簽 實(shí)現(xiàn), 而 choose 標(biāo)簽類似于Java 中的switch語句。
6.添加用戶怎么寫接口和mapper.xml
定義接口
寫mapper,使用的是<insert></insert>
封裝對象,執(zhí)行方法
7.添加信息時(shí),如果要主鍵增長呢
添加?
useGeneratedKeys, keyProperty 關(guān)鍵字
8.修改信息
定義接口
編寫mapper.xml
執(zhí)行方法
9.刪除一行數(shù)據(jù)
10.批量刪除☆☆☆
編寫SQL時(shí)需要遍歷數(shù)組來拼接SQL語句。Mybatis 提供了 foreach 標(biāo)簽供我們使用
MyBatis注解
注解是用來替換映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中書寫對應(yīng)的 statement。
使用注解開發(fā)會(huì)比配置文件開發(fā)更加方便。如下就是使用注解進(jìn)行開發(fā)。
但是對于復(fù)雜的SQL語句還是建議使用配置文件的方法。
增
public interface UserMapper {@Insert("INSERT INTO users(username, age) VALUES(#{username}, #{age})")int insertUser(User user);
}
刪
public interface UserMapper {@Delete("DELETE FROM users WHERE id = #{id}")int deleteUserById(@Param("id") int id);
}
改
public interface UserMapper {@Update("UPDATE users SET username = #{username}, age = #{age} WHERE id = #{id}")int updateUser(User user);
}
查
public interface UserMapper {@Select("SELECT * FROM users WHERE id = #{id}")User selectUserById(@Param("id") int id);// 查詢所有用戶@Select("SELECT * FROM users")List<User> selectAllUsers();
}