Mybatis分頁(yè)的實(shí)現(xiàn)及使用注解開(kāi)發(fā)操作
分頁(yè)的實(shí)現(xiàn)
sql的分頁(yè)語(yǔ)句為(第一個(gè)參數(shù)為當(dāng)前頁(yè)面的索引起始位置,第二個(gè)參數(shù)為頁(yè)面的展示個(gè)數(shù))
select * from user limit #{startIndex},#{pageSize}; # startIndex : 起始位置 ,默認(rèn)是0開(kāi)始 # pageSize :頁(yè)面大小 # 如何計(jì)算出當(dāng)前頁(yè)面索引起始位置 # currentPage = (currentPage-1)* pageSize
limit實(shí)現(xiàn)分頁(yè)
1、編寫(xiě)dao接口
//查詢(xún)?nèi)坑脩?hù)實(shí)現(xiàn)分頁(yè) List<User> selectUserByLimit(Map<String,Integer> map);
2、編寫(xiě)對(duì)應(yīng)mapper映射文件的方法(參數(shù)我們可以使用map封裝,方便參數(shù)傳遞)
<select id="selectUserByLimit" parameterType="Map" resultType="User"> select * from mybatis.user limit #{startIndex},#{pageSize} </select>
3、創(chuàng)建了獲取sqlSession對(duì)象的工具類(lèi),并使之可以進(jìn)行自動(dòng)提交事務(wù)
package com.MLXH.utils; 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 java.io.IOException; import java.io.InputStream; //mybatis的工具類(lèi),重復(fù)的代碼的提純 public class MyBatisUtils { //類(lèi)變量不需要設(shè)置默認(rèn)值; private static SqlSessionFactory sqlSessionFactory; static { //在maven中,所有的資源文件一般都放在resources目錄下,我們可以直接拿到。 try { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } catch (IOException e) { e.printStackTrace(); } } //設(shè)置SqlSessionFactory公共的方法 public static SqlSessionFactory getSqlSessionFactory(){ return sqlSessionFactory; } //獲得一個(gè)帶事務(wù)自動(dòng)提交功能的SqlSession公共的方法 public static SqlSession getSqlSession(){ //自動(dòng)提交事務(wù) return sqlSessionFactory.openSession(true); } }
RowBounds實(shí)現(xiàn)分頁(yè)
1、寫(xiě)接口
//查詢(xún)?nèi)坑脩?hù)實(shí)現(xiàn)分頁(yè)使用RowBounds List<User> selectUserByRowBounds();
2、寫(xiě)Mapper映射文件
<select id="selectUserByRowBounds" resultType="User"> select * from mybatis.user </select>
3、工具類(lèi)同上(只是為了獲取sqlSession對(duì)象簡(jiǎn)單而已)
4、編寫(xiě)測(cè)試代碼
@Test public void selectUserByRowBounds(){ //創(chuàng)建sqlSession SqlSessionFactory sqlSessionFactory = MyBatisUtils.getSqlSessionFactory(); SqlSession sqlSession = sqlSessionFactory.openSession(); int currentPage = 2; //當(dāng)前頁(yè) int pageSize = 2; //頁(yè)面大小 RowBounds rowBounds = new RowBounds((currentPage - 1) * pageSize, pageSize); //注意點(diǎn);使用RowBounds就不能使用getMapper了 //selectList: 接收一個(gè)List //selectMap: 接收一個(gè)Map //selectOne : 接收只有一個(gè)對(duì)象的時(shí)候 List<User> users = sqlSession.selectList("com.MLXH.dao.UserDao.selectUserByRowBounds", null, rowBounds); for (User user : users) { System.out.println(user); } }
兩者的區(qū)別
- rowBounds 本質(zhì)就是封裝了limit
- limit 是在SQL層面實(shí)現(xiàn)分頁(yè),在測(cè)試中使用getMapper獲得對(duì)象
- rowBounds 在代碼層面實(shí)現(xiàn)分頁(yè),創(chuàng)建rowBounds對(duì)象
注解開(kāi)發(fā)
根據(jù)之前寫(xiě)的這篇博客,鏈接: 使用Mybatis實(shí)現(xiàn)數(shù)據(jù)庫(kù)的增刪改查實(shí)例.(內(nèi)有詳細(xì)的代碼和目錄布局)
可以發(fā)現(xiàn),對(duì)UserDao接口,我們需要?jiǎng)?chuàng)建一個(gè)userMapper.xml來(lái)實(shí)現(xiàn)這個(gè)接口,并在其內(nèi)部寫(xiě)入sql語(yǔ)句
接下來(lái)我們使用注解來(lái)簡(jiǎn)化其代碼操作
package com.MLXH.dao; import com.MLXH.pojo.User; import org.apache.ibatis.annotations.*; import java.util.List; public interface UserDao { //查詢(xún)?nèi)坑脩?hù) @Select("select * from user") List<User> getUserList(); //通過(guò)ID查詢(xún)用戶(hù) @Select("select * from user where id = #{id}") User getUserById(@Param("id") int id); //添加用戶(hù) @Insert("insert into user(id,name,pwd) values (#{id},#{name},#{pwd})") int addUser(User user); //修改用戶(hù)信息 @Update("update user set name = #{name}, pwd = #{pwd} where id = #{id}") int updateUser(User user); //刪除用戶(hù) @Delete("delete from user where id =#{uid}") int deleteUser(@Param("uid") int id); }
UserDao
package com.MLXH.dao; import com.MLXH.pojo.User; import org.apache.ibatis.annotations.*; import java.util.List; public interface UserDao { //查詢(xún)?nèi)坑脩?hù) @Select("select * from user") List<User> getUserList(); //通過(guò)ID查詢(xún)用戶(hù) @Select("select * from user where id = #{id}") User getUserById(@Param("id") int id); //添加用戶(hù) @Insert("insert into user(id,name,pwd) values (#{id},#{name},#{pwd})") int addUser(User user); //修改用戶(hù)信息 @Update("update user set name = #{name}, pwd = #{pwd} where id = #{id}") int updateUser(User user); //刪除用戶(hù) @Delete("delete from user where id =#{uid}") int deleteUser(@Param("uid") int id); }
@Param為參數(shù)注解,當(dāng)所傳入的參數(shù)為一個(gè)時(shí),默認(rèn)為Param,但當(dāng)傳入的參數(shù)為多個(gè)時(shí),每一個(gè)參數(shù)前都要加入@Param來(lái)標(biāo)識(shí)其是一個(gè)參數(shù)
例如:
int update(@Param("id") int id,@Param("name") String name,@Param("pwd") String pwd)
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> <!--配置文件修改--> <properties resource="database.properties"/> <!--Mybatis設(shè)置--> <settings> <!--默認(rèn)日志實(shí)現(xiàn)--> <!--<setting name="logImpl" value="STDOUT_LOGGING"/>--> <!--Log4j實(shí)現(xiàn)--> <setting name="logImpl" value="LOG4J"/> </settings> <!--配置別名--> <typeAliases> <!--<typeAlias type="com.MLXH.pojo.User" alias="User"/>--> <package name="com.MLXH.pojo"/> </typeAliases> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource> </environment> </environments> <mappers> <!--class對(duì)應(yīng)的是一個(gè)接口類(lèi)--> <!--resource對(duì)應(yīng)的是一個(gè)接口類(lèi)的映射文件--> <mapper class="com.MLXH.dao.UserDao"/> </mappers> </configuration>
這里我們將創(chuàng)建sqlSession對(duì)象封裝為一個(gè)工具方法,并設(shè)置了事務(wù)的自動(dòng)提交(sqlSessionFactory.openSession(true))
工具類(lèi)
package com.MLXH.utils; 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 java.io.IOException; import java.io.InputStream; //mybatis的工具類(lèi),重復(fù)的代碼的提純 public class MyBatisUtils { //類(lèi)變量不需要設(shè)置默認(rèn)值; private static SqlSessionFactory sqlSessionFactory; static { //在maven中,所有的資源文件一般都放在resources目錄下,我們可以直接拿到。 try { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } catch (IOException e) { e.printStackTrace(); } } //設(shè)置SqlSessionFactory公共的方法 public static SqlSessionFactory getSqlSessionFactory(){ return sqlSessionFactory; } //獲得一個(gè)帶事務(wù)自動(dòng)提交功能的SqlSession公共的方法 public static SqlSession getSqlSession(){ //自動(dòng)提交事務(wù) return sqlSessionFactory.openSession(true); } }
測(cè)試
package com.MLXH.dao; import com.MLXH.pojo.User; import com.MLXH.utils.MyBatisUtils; import org.apache.ibatis.session.SqlSession; import org.junit.Test; import sun.rmi.server.UnicastServerRef; import java.util.List; public class UserDaoTest { @Test public void getUserList(){ SqlSession sqlSession = MyBatisUtils.getSqlSession();//帶自動(dòng)提交事務(wù) UserDao mapper = sqlSession.getMapper(UserDao.class); List<User> userList = mapper.getUserList(); for (User user : userList) { System.out.println(user); } sqlSession.close();//關(guān)閉sqlSession; } @Test public void getUserById(){ SqlSession sqlSession = MyBatisUtils.getSqlSession();//帶自動(dòng)提交事務(wù) UserDao mapper = sqlSession.getMapper(UserDao.class); User user = mapper.getUserById(1); System.out.println(user); sqlSession.close();//關(guān)閉sqlSession; } @Test public void addUser(){ SqlSession sqlSession = MyBatisUtils.getSqlSession();//帶自動(dòng)提交事務(wù) UserDao mapper = sqlSession.getMapper(UserDao.class); User user = new User(5, "寒雪", "hanxue"); int i = mapper.addUser(user); System.out.println(i); sqlSession.close();//關(guān)閉sqlSession; } @Test public void updateUser(){ SqlSession sqlSession = MyBatisUtils.getSqlSession();//帶自動(dòng)提交事務(wù) UserDao mapper = sqlSession.getMapper(UserDao.class); User user = new User(5, "暮凌寒雪", "mulinghanxue"); int i = mapper.updateUser(user); System.out.println(i); sqlSession.close();//關(guān)閉sqlSession; } @Test public void deleteUser(){ SqlSession sqlSession = MyBatisUtils.getSqlSession();//帶自動(dòng)提交事務(wù) UserDao mapper = sqlSession.getMapper(UserDao.class); int i = mapper.deleteUser(5); System.out.println(i); sqlSession.close();//關(guān)閉sqlSession; } }
總結(jié):
可以看到,注解開(kāi)發(fā)其實(shí)就是將接口的mapper實(shí)現(xiàn)文件封裝,并在接口方法上添加了sql語(yǔ)句…
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
線(xiàn)程池之newFixedThreadPool定長(zhǎng)線(xiàn)程池的實(shí)例
這篇文章主要介紹了線(xiàn)程池之newFixedThreadPool定長(zhǎng)線(xiàn)程池的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Java基礎(chǔ)之JDK1.8新特性lambda表達(dá)式詳解
函數(shù)式接口有且僅有一個(gè)抽象方法,但是可以有多個(gè)非抽象方法的接口,函數(shù)式接口可以被隱式轉(zhuǎn)換為lambda表達(dá)式,這篇文章主要介紹了Java基礎(chǔ)之lambda表達(dá)式(JDK1.8新特性),需要的朋友可以參考下2023-08-08java基本教程之多線(xiàn)程基本概念 java多線(xiàn)程教程
多線(xiàn)程是Java中不可避免的一個(gè)重要主體。下面是對(duì)“JDK中新增JUC包”之前的Java多線(xiàn)程內(nèi)容的講解,JUC包是由Java大師Doug Lea完成并在JDK1.5版本添加到Java中的2014-01-01Java窗體動(dòng)態(tài)加載磁盤(pán)文件的實(shí)現(xiàn)方法
這篇文章主要介紹了Java窗體動(dòng)態(tài)加載磁盤(pán)文件的實(shí)現(xiàn)方法,需要的朋友可以參考下2014-03-03如何剔除eureka無(wú)效和down狀態(tài)的問(wèn)題
這篇文章主要介紹了如何剔除eureka無(wú)效和down狀態(tài)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07SpringBoot實(shí)現(xiàn)發(fā)送電子郵件
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)發(fā)送電子郵件,電子郵件是—種用電子手段提供信息交換的通信方式,是互聯(lián)網(wǎng)應(yīng)用最廣的服務(wù)。通過(guò)網(wǎng)絡(luò)的電子郵件系統(tǒng),用戶(hù)可以非??焖俚姆绞?,與世界上任何一個(gè)角落的網(wǎng)絡(luò)用戶(hù)聯(lián)系,下面就來(lái)看看SpringBoot如何實(shí)現(xiàn)發(fā)送電子郵件吧2022-01-01Spring Boot 2.2 正式發(fā)布,大幅性能提升 + Java 13 支持
隨著 Spring Framework 5.2.0 成功發(fā)布之后,Spring Boot 2.2 也緊跟其后,發(fā)布了第一個(gè)版本:2.2.0。下面就來(lái)一起來(lái)看看這個(gè)版本都更新了些什么值得我們關(guān)注的內(nèi)容2019-10-10使用@value注解取不到application.xml配置文件中的值問(wèn)題
這篇文章主要介紹了使用@value注解取不到application.xml配置文件中的值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03