教我做網(wǎng)站立即優(yōu)化在哪里
目錄
前言
MyBatis的具體使用
一些小工具:MyBatisX
常見問題:
1.表中字段名和實體屬性名不一致
2.按條件查詢(單條件)時的,查詢條件怎么編寫
3.按條件查詢(多條件)
4.多條件查詢時,用戶不把所有條件填完
5.單條件查詢時,不知道用戶到底選了哪一個
6.添加用戶怎么寫接口和mapper.xml
7.添加信息時,如果要主鍵增長呢
8.修改信息
9.刪除一行數(shù)據(jù)
10.批量刪除☆☆☆
MyBatis注解
增
刪
改
查
前言
為什么要有MyBatis呢?
當然是因為JDBC代碼太繁瑣啦~
上圖標1的代碼有很多字符串,而這些是連接數(shù)據(jù)庫的四個基本信息,以后如果要將Mysql數(shù)據(jù)庫換成其他的關系型數(shù)據(jù)庫的話,這四個地方都需要修改,如果放在此處就意味著要修改我們的源代碼。
上圖標2的代碼。如果表結構發(fā)生變化,SQL語句就要進行更改。這也不方便后期的維護。
操作很繁瑣
使用MyBatis就可以解決這些問題
MyBatis的具體使用
1.創(chuàng)建一個表。
2.導入依賴坐標
3.在項目的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中可以不用設置成這樣了 --><!-- <select id="selectAll" resultType="org.example.pojo.User">--><!-- 因為在mybatis中配置了別名,所以可以不用謝前面的包名了 -->
<!-- <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映射的路徑 -->
<!-- 因為在resource目錄上有和src目錄下的下相同目錄,所以直接可以使用package包的方式 --><mappers>
<!-- <mapper resource="org/example/mapper/UserMapper.xml"/>--><package name="org.example.mapper"/></mappers>
</configuration>
4.創(chuàng)建實體類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.定義一個測試類進行測試
/*** 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映射配置文件 和 接口方法 間相互跳轉
-
根據(jù)接口方法生成 statement
如下圖操作就可以完成,生成Mapper.xml文件中的statement
常見問題:
1.表中字段名和實體屬性名不一致
使用Mybatis時,可能會出現(xiàn)數(shù)據(jù)庫表的字段名稱和實體類的屬性名稱不一樣的問題,這樣的話就不能自動封裝數(shù)據(jù)了。
可以resultMap
具體來說:就是在 **Mapper.xml中添加下圖紅框框住的<resultMap></resultMap>部分,對字段進行映射,下圖中前面的字段是數(shù)據(jù)庫中的命名,后面是實體類的屬性名。
然后將resultType換成resultMap
2.按條件查詢(單條件)時的,查詢條件怎么編寫
在 **Mapper中這樣寫,如下圖查詢條件是id? 就這樣寫#{id}
對于有參數(shù)的Mapper接口方法
3.按條件查詢(多條件)
可以使用以下三種方法
mapper.xml的編寫
在測試類中的調(diào)用
4.多條件查詢時,用戶不把所有條件填完
這個時候就要使用到動態(tài)SQL
使用<where></where>標簽 和 <if></if>標簽
5.單條件查詢時,不知道用戶到底選了哪一個
這種需求需要使用到 choose(when,otherwise)標簽 實現(xiàn), 而 choose 標簽類似于Java 中的switch語句。
6.添加用戶怎么寫接口和mapper.xml
定義接口
寫mapper,使用的是<insert></insert>
封裝對象,執(zhí)行方法
7.添加信息時,如果要主鍵增長呢
添加?
useGeneratedKeys, keyProperty 關鍵字
8.修改信息
定義接口
編寫mapper.xml
執(zhí)行方法
9.刪除一行數(shù)據(jù)
10.批量刪除☆☆☆
編寫SQL時需要遍歷數(shù)組來拼接SQL語句。Mybatis 提供了 foreach 標簽供我們使用
MyBatis注解
注解是用來替換映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中書寫對應的 statement。
使用注解開發(fā)會比配置文件開發(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();
}