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 ...
随机推荐
- Greenplum列存压缩表索引机制
列存压缩表,简称AOCS表 数据生成 create table testao(date text, time text, open float, high float, low float, volu ...
- Vim Configuration
安装原生态的Vim之后,界面是这样的: 行号,没有:自动缩进,没有:括号匹配,没有~ 为了我们使用的方便,进行一些基本的配置: sudo vim /etc/vim/vimrc 进入配置界面: 如下图进 ...
- linux多线程同步的四种方式
1. 在并发情况下,指令执行的先后顺序由内核决定.同一个线程内部,指令按照先后顺序执行,但不同线程之间的指令很难说清楚是哪一个先执行.如果运行的结果依赖于多线程执行的顺序,那么就会形成竞争条件,每次运 ...
- 2020牛客寒假算法基础集训营1 J题可以回顾回顾
2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...
- T - zxa and leaf HDU - 5682 二分+dfs
T - zxa and leaf HDU - 5682 题目大意是:给你一颗树,这棵树有些节点已经设置了它的美丽值,然后剩下一些节点需要我们设置美丽值. 一条边的丑陋程度等于被定义为由这个边缘连接的两 ...
- Spring官网阅读(八)容器的扩展点(三)(BeanPostProcessor)
在前面两篇关于容器扩展点的文章中,我们已经完成了对BeanFactoryPostProcessor很FactoryBean的学习,对于BeanFactoryPostProcessor而言,它能让我们对 ...
- 【T-SQL】基础——表别名
Som有时候我们需要为表设置别名,这样就可以方便的修改表. 如果在SSMS中,可以点击 Query-> SQL CMD mode --Set Alisa for the table:setvar ...
- LeetCode--Array--Container With Most Water (Medium)
11. Container With Most Water (Medium)# Given n non-negative integers a1, a2, ..., an , where each r ...
- JMeter-SHA256加密算法接口测试
前言 我们已经学过了如何利用python脚本对SHA256加密接口进行测试,还没学会的小伙伴们可以看回我写的随笔Python-SHA256加密算法接口测试,那么,对于SHA256加密算法接口,我们如何 ...
- 谈谈DDD
从战略到战术,领域驱动设计(Domain Driven Design,DDD)给出了诸多关于软件架构.设计.建模与编码的方法和模式,以用于应对业务复杂度.然而,许多开发人员对于 DDD 的价值仍然心存 ...