pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.xf</groupId>
<artifactId>Mymybatis</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.25</version>
</dependency>
</dependencies>
<build>
<!--解决xml没有到target-->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
</project>
config.xml:
<?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>
<typeAliases>
<typeAlias type="com.xf.mybatis.pojo.User" alias="user"/>
</typeAliases>
<!-- 配置MyBatis运行环境 -->
<environments default="development">
<environment id="development">
<!-- 配置JDBC事务管理 -->
<transactionManager type="JDBC"></transactionManager>
<!-- POOLED配置JDBC数据源连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://120.78.195.41:3306/test?useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="***"/>
<property name="password" value="***"/>
</dataSource>
</environment>
</environments>
<!--注册UserMapper.xml-->
<mappers>
<!--分页-->
<mapper resource="com/xf/mybatis/mapper/UserMapperPage.xml"/>
</mappers>
</configuration>
User:
package com.xf.mybatis.pojo;
public class User {
private int id;
private String username;
private String password;
private int age;
public User() {
}
public User(int id, String username, String password, int age) {
this.id = id;
this.username = username;
this.password = password;
this.age = age;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
", age=" + age +
'}';
}
}
UserMapper.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="com.xf.mybatis.pojo.User">
<resultMap type="user" id="userMap">
<id property="id" column="id"/>
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="age" column="age"/>
</resultMap>
<select id="findAllWithFy" parameterType="map" resultMap="userMap">
SELECT id,username,password,age FROM t_user limit #{pstart},#{psize}
</select>
<select id="findAllByNameWithFy" parameterType="map" resultMap="userMap">
select id,username,password,age
from t_user
where username like #{pname}
limit #{pstart},#{psize}
</select>
</mapper>
UserDao:
package com.xf.mybatis.Dao;
import com.xf.mybatis.pojo.User;
import com.xf.mybatis.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
public class UserDaoPage {
/**
* 无条件分页
* @param start
* @param size
* @return
* @throws Exception
*/
public List<User> findAllWithFy(int start,int size) throws Exception{
SqlSession sqlSession=null;
try {
sqlSession= MybatisUtil.getSqlSession();
Map<String,Object> map=new LinkedHashMap<String,Object>();
map.put("pstart",start);
map.put("psize",size);
return sqlSession.selectList(User.class.getName()+".findAllWithFy",map);
}catch (Exception e){
e.printStackTrace();
throw e;
}finally {
MybatisUtil.closeSqlSession();
}
}
/**
* 有条件分页
*/
public List<User> findAllByNameWithFy(String name,int start,int size) throws Exception{
SqlSession sqlSession = null;
try{
sqlSession = MybatisUtil.getSqlSession();
Map<String,Object> map = new LinkedHashMap<String, Object>();
map.put("pname","%"+name+"%");
map.put("pstart",start);
map.put("psize",size);
return sqlSession.selectList(User.class.getName()+".findAllByNameWithFy",map);
}catch(Exception e){
e.printStackTrace();
throw e;
}finally{
MybatisUtil.closeSqlSession();
}
}
public static void main(String[] args) throws Exception {
UserDaoPage dao=new UserDaoPage();
/* System.out.println("--------------------第一页");
List<User> studentList1 = dao.findAllWithFy(0,3);
for(User s : studentList1){
System.out.println(s.getId()+":"+s.getUsername()+":"+s.getPassword()+":"+s.getAge());
}
System.out.println("--------------------第二页");
List<> studentList2 = dao.findAllWithFy(3,3);
for(UseUserr s : studentList2){
System.out.println(s.getId()+":"+s.getUsername()+":"+s.getPassword()+":"+s.getAge());
}
System.out.println("--------------------第三页");
List<User> studentList3 = dao.findAllWithFy(6,3);
for(User s : studentList3){
System.out.println(s.getId()+":"+s.getUsername()+":"+s.getPassword()+":"+s.getAge());
}*/
System.out.println("--------------------第一页");
List<User> studentList1 = dao.findAllByNameWithFy("哈哈",0,3);
for(User s : studentList1){
System.out.println(s.getId()+":"+s.getUsername()+":"+s.getPassword()+":"+s.getAge());
}
System.out.println("--------------------第二页");
List<User> studentList2 = dao.findAllByNameWithFy("哈哈",3,3);
for(User s : studentList2){
System.out.println(s.getId()+":"+s.getUsername()+":"+s.getPassword()+":"+s.getAge());
}
}
}