文件目录

写一下每个文件的代码

 UserDao.java

package cn.zys.dao;

import java.io.IOException;
import java.util.List; import org.apache.ibatis.session.SqlSession; import cn.zys.entity.User;
import cn.zys.until.MyBatisUtils; public class UserDao {
//根据id查用户
public User getById(int id) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
User user = sqlsession.selectOne("cn.zys.entity.UserMapper.selectUser", id);
/*System.out.println(user.toString());*/
sqlsession.close();
return user;
} //查询所有用户
public List<User> selectAll() throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
List<User> list = sqlsession.selectList("cn.zys.entity.UserMapper.selectAll");
sqlsession.close();
return list;
} //添加用户
public int addUser(User user) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
int res = sqlsession.insert("cn.zys.entity.UserMapper.insertUser",user);
sqlsession.commit();
sqlsession.close();
return res;
} //更新用户
public int updateUser(User user) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
int res = sqlsession.update("cn.zys.entity.UserMapper.updateUser",user);
sqlsession.commit();
sqlsession.close();
return res;
} //删除用户
public int deleteUser(int id) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
int res = sqlsession.delete("cn.zys.entity.UserMapper.deleteUser",id);
sqlsession.commit();
sqlsession.close();
return res;
}
//分页查询
public List<User> selectLimt(int startindex,int pagenum) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
Map<String,Integer> maps = new HashMap<String, Integer>();
maps.put("startindex", (startindex-1)*pagenum);
maps.put("pagenum", pagenum);
List<User> list = sqlsession.selectList("cn.zys.entity.UserMapper.selectLimit",maps);
sqlsession.commit();
sqlsession.close();
return list;
} //rowbangs分页查询
public List<User> selectLimts(int startindex,int pagenum) throws IOException{
SqlSession sqlsession = MyBatisUtils.getSqlSession();
RowBounds rowbounds = new RowBounds((startindex-1)*pagenum,pagenum);
List<User> list = sqlsession.selectList("cn.zys.entity.UserMapper.selectLimits",null,rowbounds);
sqlsession.commit();
sqlsession.close();
return list;
}
}

User.java

package cn.zys.entity;

public class User {
private int id;
private String name;
private String pwd;
//
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", pwd=" + pwd + "]";
}
}

user-mappers.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 -->
<mapper namespace="cn.zys.entity.UserMapper">
<select id="selectUser" resultType="User">
select * from user where id = #{id}
</select> <!-- 查询所有 -->
<select id="selectAll" resultType="User" 返回值类型 >
select * from user
</select>
    <!-- 分页 -->
<select id="selectLimit" parameterType="Map" resultType="User">
select * from user limit #{startindex},#{pagenum}
</select> <!-- 使用rowbangs分页 -->
<select id="selectLimits" parameterType="Map" resultType="User">
select * from user
</select>
    <insert id="insertUser" parameterType="User" 此处的属性为参数类型 useGeneratedKeys="true" 此处属性为是否使用自增字段 >   增删改默认返回int类型
insert into user(name,pwd) values(#{name},#{pwd})
</insert> <update id="updateUser" parameterType="User" >
update user set name=#{name},pwd=#{pwd} where id=#{id}
</update> <delete id="deleteUser" >
delete from user where id=#{id}
</delete>
</mapper>

MyBatisUtils.java

package cn.zys.until;

import java.io.IOException;
import java.io.InputStream; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MyBatisUtils {
public static SqlSessionFactory getSqlSessionFactory() throws IOException{
String resource = "mybatis.config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
return sqlSessionFactory;
} public static SqlSession getSqlSession() throws IOException{
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
return sqlSessionFactory.openSession();
}
}

db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis1
username=root
password=root

mybatis.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>
<!-- 外部引入数据库配置 -->
<properties resource="db.properties"></properties> <!-- 为某个类型指定别名 方便在某个引用时使用 比如传值 在此处使用在 user-mappers.xml的resultType -->
<typeAliases>
<!-- <typeAlias type="cn.zys.entity.User" alias="User" /> -->
<!-- 为某个包下的所有类指定别名 默认别名是对应类名 -->
<package name="cn.zys.entity" />
</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>
<mapper resource="cn/zys/entity/user-mappers.xml"/>
</mappers>
</configuration>

test.java

package cn.zys.test;

import java.io.IOException;
import java.util.List; import cn.zys.dao.UserDao;
import cn.zys.entity.User; public class test {
public static void main(String[] args) throws IOException {
UserDao userdao = new UserDao();
     

      //新用户
      /* User user = new User();
      user.setName("002");
      user.setPwd("002");
      userdao.addUser(user);*/

      //分页测试
      List<User> list = userdao.selectLimts(0, 2);
      System.out.println(list);

    }
}

最后的测试中只测试了最后一个查询多条数据

MyBatis的使用增删改查(两种分页查询)的更多相关文章

  1. MyBatis简单的增删改查以及简单的分页查询实现

    MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...

  2. Mybatis入门之增删改查

    Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...

  3. MyBatis -- 对表进行增删改查(基于注解的实现)

    1.MyBatis对数据库表进行增/删/改/查 前一篇使用基于XML的方式实现对数据库的增/删/改/查 以下我们来看怎么使用注解的方式实现对数据库表的增/删/改/查 1.1  首先须要定义映射sql的 ...

  4. Spring Boot 使用Mybatis注解开发增删改查

    使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...

  5. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

  6. JavaWeb系统(增删改查、多条件查询功能)

    该系统是一个简单的青年服务管理系统,主要包括了较完整的常用的增删改查以及多条件查询功能,对于初学者有很大帮助. 下面是相关的Java代码.jsp页面.以及数据库的创建和相关表的设计 java代码 首先 ...

  7. mybatis:开发环境搭建--增删改查--多表联合查询(多对一)

    什么是mybatisMyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyBatis使用简单的XML或 ...

  8. SpringMVC,MyBatis商品的增删改查

    一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...

  9. 基于SSM之Mybatis接口实现增删改查(CRUD)功能

    国庆已过,要安心的学习了. SSM框架以前做过基本的了解,相比于ssh它更为优秀. 现基于JAVA应用程序用Mybatis接口简单的实现CRUD功能: 基本结构: (PS:其实这个就是用的Mapper ...

随机推荐

  1. Vue项目中实现图片懒加载

    个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! ---对于图片过多的页面,为了加速页面加载速度,所以很多时候我们需要将页面 ...

  2. cookie ,session 和localStorage的区别详解

    2019独角兽企业重金招聘Python工程师标准>>> cookie ,session 和localStorage的区别详解 博客分类: js 当你在浏览网站的时候,WEB 服务器会 ...

  3. Algorithm Exercises

    汇总一些常见的算法题目,参考代码. 注:部分题目没有合适的oj地址 枚举 Perfect Cubes.Biorhythms.Counterfeit Dollar.EXTENDED LIGHTS OUT ...

  4. Codeforce 1251C. Minimize The Integer

    C. Minimize The Integer time limit per test2 seconds memory limit per test256 megabytes inputstandar ...

  5. P2480 [SDOI2010]古代猪文

    P2480 [SDOI2010]古代猪文 比较综合的一题 前置:Lucas 定理,crt 求的是: \[g^x\bmod 999911659,\text{其中}x=\sum_{d\mid n}\tbi ...

  6. P2765 魔术球问题 网络流二十四题重温

    P2765 魔术球问题 知识点::最小点覆盖 这个题目要拆点,这个不是因为每一个球只能用一次,而是因为我们要求最小点覆盖,所以要拆点来写. 思路: 首先拆点,然后就是开始建边,因为建边的条件是要求他们 ...

  7. 如何在Windows下安装MySQL5和MySQL8的多实例

    MySQL5和MySQL8多实例安装方法: 1.首先下载MySQL5和MySQL8 官方下载链接:https://dev.mysql.com/downloads/mysql/  下载旧版本: 下载好后 ...

  8. Spring 中基于 AOP 的 @AspectJ注解实例

    @AspectJ 作为通过 Java 5 注释注释的普通的 Java 类,它指的是声明 aspects 的一种风格.通过在你的基于架构的 XML 配置文件中包含以下元素,@AspectJ 支持是可用的 ...

  9. matlab 提示 Continuous sample time is not supported by discrete derivative 错误的解决办法

    Simulink仿真的时候,出行错误提示:Continuous sample time is not supported by discrete derivative 中文意思是:连续采样时间不支持离 ...

  10. Linux文件操作命令并举例说明其作用

    ls ,常用于查看当前文件下有工作中需要的文件 cd, 常用于进行切换文件的位置 vim,常用于编辑软件系统相关的配置文件 ps –ef|grep jdk,常用语显示跟jdk有关的进程   |:表示 ...