欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis分頁(yè)的實(shí)現(xiàn)及使用注解開(kāi)發(fā)操作

 更新時(shí)間:2021年06月21日 10:09:48   作者:_板藍(lán)根_  
這篇文章主要介紹了Mybatis分頁(yè)的實(shí)現(xiàn)及使用注解開(kāi)發(fā)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

分頁(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)文章

最新評(píng)論