MyBatis的使用增删改查(两种分页查询)
文件目录

写一下每个文件的代码
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的使用增删改查(两种分页查询)的更多相关文章
- MyBatis简单的增删改查以及简单的分页查询实现
MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...
- Mybatis入门之增删改查
Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...
- MyBatis -- 对表进行增删改查(基于注解的实现)
1.MyBatis对数据库表进行增/删/改/查 前一篇使用基于XML的方式实现对数据库的增/删/改/查 以下我们来看怎么使用注解的方式实现对数据库表的增/删/改/查 1.1 首先须要定义映射sql的 ...
- Spring Boot 使用Mybatis注解开发增删改查
使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...
- Mybatis实现简单增删改查
Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...
- JavaWeb系统(增删改查、多条件查询功能)
该系统是一个简单的青年服务管理系统,主要包括了较完整的常用的增删改查以及多条件查询功能,对于初学者有很大帮助. 下面是相关的Java代码.jsp页面.以及数据库的创建和相关表的设计 java代码 首先 ...
- mybatis:开发环境搭建--增删改查--多表联合查询(多对一)
什么是mybatisMyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyBatis使用简单的XML或 ...
- SpringMVC,MyBatis商品的增删改查
一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...
- 基于SSM之Mybatis接口实现增删改查(CRUD)功能
国庆已过,要安心的学习了. SSM框架以前做过基本的了解,相比于ssh它更为优秀. 现基于JAVA应用程序用Mybatis接口简单的实现CRUD功能: 基本结构: (PS:其实这个就是用的Mapper ...
随机推荐
- Vue项目中实现图片懒加载
个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! ---对于图片过多的页面,为了加速页面加载速度,所以很多时候我们需要将页面 ...
- cookie ,session 和localStorage的区别详解
2019独角兽企业重金招聘Python工程师标准>>> cookie ,session 和localStorage的区别详解 博客分类: js 当你在浏览网站的时候,WEB 服务器会 ...
- Algorithm Exercises
汇总一些常见的算法题目,参考代码. 注:部分题目没有合适的oj地址 枚举 Perfect Cubes.Biorhythms.Counterfeit Dollar.EXTENDED LIGHTS OUT ...
- Codeforce 1251C. Minimize The Integer
C. Minimize The Integer time limit per test2 seconds memory limit per test256 megabytes inputstandar ...
- P2480 [SDOI2010]古代猪文
P2480 [SDOI2010]古代猪文 比较综合的一题 前置:Lucas 定理,crt 求的是: \[g^x\bmod 999911659,\text{其中}x=\sum_{d\mid n}\tbi ...
- P2765 魔术球问题 网络流二十四题重温
P2765 魔术球问题 知识点::最小点覆盖 这个题目要拆点,这个不是因为每一个球只能用一次,而是因为我们要求最小点覆盖,所以要拆点来写. 思路: 首先拆点,然后就是开始建边,因为建边的条件是要求他们 ...
- 如何在Windows下安装MySQL5和MySQL8的多实例
MySQL5和MySQL8多实例安装方法: 1.首先下载MySQL5和MySQL8 官方下载链接:https://dev.mysql.com/downloads/mysql/ 下载旧版本: 下载好后 ...
- Spring 中基于 AOP 的 @AspectJ注解实例
@AspectJ 作为通过 Java 5 注释注释的普通的 Java 类,它指的是声明 aspects 的一种风格.通过在你的基于架构的 XML 配置文件中包含以下元素,@AspectJ 支持是可用的 ...
- matlab 提示 Continuous sample time is not supported by discrete derivative 错误的解决办法
Simulink仿真的时候,出行错误提示:Continuous sample time is not supported by discrete derivative 中文意思是:连续采样时间不支持离 ...
- Linux文件操作命令并举例说明其作用
ls ,常用于查看当前文件下有工作中需要的文件 cd, 常用于进行切换文件的位置 vim,常用于编辑软件系统相关的配置文件 ps –ef|grep jdk,常用语显示跟jdk有关的进程 |:表示 ...