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 ...
随机推荐
- muduo网络库源码学习————线程类
muduo库里面的线程类是使用基于对象的编程思想,源码目录为muduo/base,如下所示: 线程类头文件: // Use of this source code is governed by a B ...
- socket编程之并发回射服务器3
在socket编程之并发回射服务器一文中,服务器采用多进程的方式实现并发,本文采用多线程的方式实现并发. 多线程相关API: // Compile and link with -pthread int ...
- PHP循环引用会遇到的坑
今天遇到这样一个问题: 如果foreach循环一个数组,引用去对它的元素做一些操作,会有什么问题吗? 比如 [1, 2, 3],foreach循环的时候,引用给每个元素 * 2,再去foreach输出 ...
- shell命令之巧用cut
需求:取出日志中ip字段,并进行统计排序 .一般用用awk命令 假如ip地址为第一个字段 那么 awk ‘{print $1}’ 文件名 |sort |uniq -c|sort-nr 那如果不是第一个 ...
- 王颖奇 20171010129《面向对象程序设计(java)》第十一周学习总结
实验十一 集合 实验时间 2018-11-8 1.实验目的与要求 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: (2) 了解java集合框架体系组成: (3) ...
- 机器学习的hello world——MNIST
MNIST:一个由60000行训练数据集和10000行的测试数据集(机器学习模型设计时必须有一个单独的数据集用于评估模型的性能)组成的数据集. 下载mnist的数据集后,将文件放入C:\Users\m ...
- STM32学习笔记——GPIO
单片机型号STM32F407VET6. 概述 GPIO的分类: 可接受5V输入的(FT),绝大多数引脚都是: 只能接受3.3V输入的(TTa),只有PA4和PA5,就是DAC输出的两个引脚: 其他,包 ...
- hex文件格式总结
hex文件格式总结 文章目录 hex文件格式总结 什么是hex文件? 文件格式 指令类型(Record type) 校验和 :04 02B0 00 92020008 AE :04 0000 05 08 ...
- STM32 TIM 编码器模式采集编码器信号
layout: post tags: [STM32] comments: true 文章目录 @[toc] 什么是正交解码? 编码器接口模式 标准库接口 TIM_TimeBaseInitTypeDef ...
- 存储过程——异常捕获&打印异常信息
目录 0. 背景说明 1. 建立异常信息表ErrorLog 2. 建立保存异常信息的存储过程 3. 建立在SQL Server中打印异常信息的存储过程 4. 建立一个用于测试的存储过程抛出异常进行测试 ...