Mybatis学习(二) - CRUD操作(增删改查操作)
直接上例子:
1.项目结构:

2.具体代码及配置
User.java
package com.mybatis.bean;
public class User {
    private int id;
    private String name;
    private int age;
    public User(int id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }
    public User(){}
    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 int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}
GetFacotry.java
package com.mybatis.util; import java.io.IOException;
import java.io.Reader; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class GetFactory { public static SqlSessionFactory getFactory(){ Reader reader= null;
try {
reader = Resources.getResourceAsReader("conf.xml");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
SqlSessionFactory sessionfactory = new SqlSessionFactoryBuilder().build(reader); return sessionfactory;
}
}
配置文件 conf.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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC">
</transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/Mybatis" />
<property name="username" value="root" />
<property name="password" value="123456" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="User.xml"></mapper>
</mappers>
</configuration>
配置文件 User.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.mybatis.bean.UserMapper">
<select id="getUser" parameterType="int" resultType="com.mybatis.bean.User">
select * from user where id=#{id}
</select>
<!--
CRUD操作
-->
<insert id="addUser" parameterType="com.mybatis.bean.User">
insert into user (name,age) values (#{name},#{age});
</insert>
<update id="updateUser" parameterType="com.mybatis.bean.User">
update user set name=#{name},age=#{age} where id=#{id}
</update>
<delete id="deleteUser" parameterType="int">
delete from user where id=#{id}
</delete>
<select id="selectAllUsers" resultType="com.mybatis.bean.User">
select * from user
</select>
</mapper>
3.单元测试
test.java
package com.mybatis.service; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test; import com.mybatis.bean.User;
import com.mybatis.util.GetFactory; public class test { @Test
public void UnitTest_ADD(){
SqlSessionFactory factory = GetFactory.getFactory();
SqlSession session = factory.openSession(); String statment = "com.mybatis.bean.UserMapper.addUser";
User user = new User(-1,"新增",32);
int insert = session.insert(statment,user);
session.commit();
session.close();
System.out.println(insert);
} @Test
public void UnitTest_UPDATE(){
SqlSessionFactory factory = GetFactory.getFactory();
SqlSession session = factory.openSession(); String statment = "com.mybatis.bean.UserMapper.updateUser";
User user = new User(1,"更新",22);
int insert = session.update(statment,user);
session.commit();
session.close();
System.out.println(insert); } @Test
public void UnitTest_DELETE(){
SqlSessionFactory factory = GetFactory.getFactory();
SqlSession session = factory.openSession(); String statment = "com.mybatis.bean.UserMapper.deleteUser";
int delete = session.delete(statment, 2);
session.commit();
session.close();
System.out.println(delete); } @Test
public void UnitTest_SELECT_ALL(){
SqlSessionFactory factory = GetFactory.getFactory();
SqlSession session = factory.openSession(); String statment = "com.mybatis.bean.UserMapper.selectAllUsers";
List<User> list= session.selectList(statment);
session.close();
System.out.println(list);
} }
Mybatis学习(二) - CRUD操作(增删改查操作)的更多相关文章
- Ecmall二次开发-增删改查操作
		
Ecmall二次开发-增删改查操作 Model目录includes/models 自己添加需要的model class OrdercomplainModel extends BaseModel //类 ...
 - MyBatis之二:简单增删改查
		
这一篇在上一篇的基础上简单讲解如何进行增删改查操作. 一.在mybatis的配置文件conf.xml中注册xml与注解映射 <!-- 注册映射文件 --> <mappers> ...
 - mybatis学习(五)——增删改查及自增主键的获取
		
一.mybatis的增删改查 1.修改hotelMapper接口 package com.pjf.mybatis.dao; import com.pjf.mybatis.po.Hotel; publi ...
 - 【Mybatis】mybatis开启Log4j日志、增删改查操作
		
Mybatis日志(最常用的Log4j) 官方网站http://www.mybatis.org/mybatis-3/zh/logging.html 1.在src目录下创建一个log4j.propert ...
 - 学习MyBatis必知必会(5)~了解myBatis的作用域和生命周期并抽取工具类MyBatisUtil、mybatis执行增删改查操作
		
一.了解myBatis的作用域和生命周期[错误的使用会导致非常严重的并发问题] (1)SqlSessionFactoryBuilder [ 作用:仅仅是用来创建SqlSessionFactory,作用 ...
 - MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
		
一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ...
 - Mybatis学习笔记之---CRUD(增删改查)
		
Mybatis的CRUD(增删改查) 1.pom.xml <dependencies> <dependency> <groupId>junit</groupI ...
 - 使用DOM进行xml文档的crud(增删改查)操作<操作详解>
		
很多朋友对DOM有感冒,这里我花了一些时间写了一个小小的教程,这个能看懂,会操作了,我相信基于DOM的其它API(如JDOM,DOM4J等)一般不会有什么问题. 后附java代码,也可以下载(可点击这 ...
 - MyBatis批量增删改查操作
		
前文我们介绍了MyBatis基本的增删该查操作,本文介绍批量的增删改查操作.前文地址:http://blog.csdn.net/mahoking/article/details/43673741 ...
 
随机推荐
- java线程控制安全
			
synchronized() 在线程运行的时候,有时会出现线程安全问题例如:买票程序,有可能会出现不同窗口买同一张编号的票 运行如下代码: public class runable implement ...
 - Linux防火墙配置—SNAT2
			
1.实验目标 以实验"Linux防火墙配置-SNAT1"为基础,为网关增加外网IP地址,为eth1创建虚拟接口,使外网测试主机在Wireshark中捕获到的地址为eth1虚拟接口的 ...
 - 使用SSH框架查出的实体集合用AJAX形式刷新到页面JOSONArray报异常
			
所报异常:net.sf.json.JSONException: java.lang.reflect.InvocationTargetException 问题根源:数据库中查出的日期是java.sql. ...
 - [Mobile Web]Web中如何分辨移动设备?(iPad、iPhone、Android)
			
第一种, Javascript [javascript] view plaincopyprint?在CODE上查看代码片派生到我的代码片 var deviceAgent = navigator.use ...
 - 转 JSON与XML转换
			
这两天处理模块的联调工作,在json与XML转换中出现了一些奇怪的问题,仔细究来,实为对org.json.*包知之太少.晚上baidu.google一下,找出了问题出现的原因.在模块中,使用了两个方法 ...
 - 时间序列预测之--ARIMA模型
			
什么是 ARIMA模型 ARIMA模型的全称叫做自回归移动平均模型,全称是(ARIMA, Autoregressive Integrated Moving Average Model).也记作ARIM ...
 - 企业Centos服务器分区常用方案
			
方案一: 一般公司生产环境,数据不是非常重要,集群架构中的一个节点服务器: /boot: 200M swap: 8G内存以下,1.5倍 8G内存以上,设置8G就够了 / : 剩下的所以存储空间 方案二 ...
 - MySQL ProxySQL读写分离使用初探
			
目的 在美团点评DBProxy读写分离使用说明文章中已经说明了使用目的,本文介绍ProxySQL的使用方法以及和DBProxy的性能差异.具体的介绍可以看官网的相关说明,并且这个中间件也是percon ...
 - 微软 Build 2017 开发者大会:Azure 与 AI 的快速发展
			
欢迎大家持续关注葡萄城控件技术团队博客,更多更好的原创文章尽在这里~~ 一年一度的微软 Build 大会准时起航,本年度大会从旧金山移师西雅图,一个近年来凭借女神汤唯而在中国家喻户晓的美国西部海滨城市 ...
 - Java Swing 图形界面实现验证码(验证码可动态刷新)
			
import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.Toolkit;import j ...