Mybatis3实现增删查改

Mybatis 的功能实现有以下几部分:

1.持久化类

2.持久化类和数据库表之间的映射(XML文件)

3.Mybatis配置文件(XML文件)

4.Java应用程序(运用Mybatis)

 

目录树:

 

在数据库中建库和数据表:

 

#建立一个名为mybatis的数据库
create database mybatis;

#使用名叫mybatis的数据库
use mybatis;

#创建一个tb_user表,有 id,name,sex 列
CREATE TABLE tb_user(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(18),sex CHAR(2)) 

 

 

1.持久化类

 

 

持久化类是应用程序中用来实现业务问题实体的类,其示例会持久化地保存在数据库中。

 

package com;

//持久化类中的项目有 id,name,sex
public class User {
	private Integer id;
	private String name;
	private String sex;
	

	public User(int id,String name, String sex) {
		super();
		this.id = id;
		this.name = name;
		this.sex = sex;
	}
	
	public User(String name, String sex) {
		super();
		this.name = name;
		this.sex = sex;
	}
	public User() {
		super();
		// TODO Auto-generated constructor stub
	}
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
	@Override
	public String toString() {
		return "Person["+id+","+name+","+sex+"]";
	}
}

 

 

2.持久化类和数据库之间的映射

 

 

对于Mybatis来说,它不理解持久化类和数据库之间的对用关系,也不理解持久化类的各项属性和数据表的各个列之间的对应关系。因此就需要以下一个XML文件来完成持久化类和数据表之间的映射关系

UserMapper.xml:(一张表一个这样的xml文件)

 

 

3.Mybatis配置文件

配置文件只有一个。

PS:

第十三行:表示使用连接池,当程序创建数据源示例时,系统会一次性地创建数据库连接,并把这些连接保存在连接池中,当程序需要进行数据库访问时,无须重新获得数据库连接,而是从连接池中取出一个空闲的数据库连接,当程序使用数据库连接结束后,就会此连接重新放回连接池。通过这种方式,就可以避免频繁地获取数据库连接,关闭连接所导致的性能下降。

 

4.java应用程序(测试程序)

Operation.java:(这个文件用于与记录与直接操作数据库的方法,供用户直接调用)

 

package com;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;
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 Operation {
	InputStream inputstream = null;
	SqlSessionFactory sqlSessionFactory = null;
	SqlSession session = null;
	

	public void init() throws IOException {	//准备工作
		inputstream = Resources.getResourceAsStream("mybatis-config.xml");//用相对路径的方法读取mybatis配置文件
																		  //并以流的形式返回
		sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputstream);//创建sqlSessionFactory
	}
	
	public void add(String name,String sex) {	//插入操作
		session = sqlSessionFactory.openSession();	//打开Session
		User user = new User(name,sex);			//创建一个持久化类作为参数
		session.insert("com.UserMapper.save",user);	//完成insert语句的拼凑,第一个参数为UserMapper.xml中的sql语句的id
		session.commit();							//提交sql语句
		session.close();							//完成操作后,关闭Session
	}
	
	public void showAll() {	//展示数据表所有数据
		session = sqlSessionFactory.openSession();	//打开Session
		List<User> user_list = session.selectList("com.UserMapper.findAll");
							//调用selectList(),并用一个List容器装载sql语句返回的结果,findAll为映射文件中对应sql语句的id
		for(User u:user_list) {		//遍历List容器
			System.out.println(u);
		}
		session.commit();			//提交sql语句
		session.close();			//关闭Session
	}

	public void findById(int id) {	//按id号查询数据表中的数据
		session = sqlSessionFactory.openSession();	//打开Seesion
		User u = session.selectOne("com.UserMapper.findbyid",id);	
							//调用selectOne(),并用一个持久化的类对象装在sql语句返回的结果。findbyid为映射文件中对应sql语句的id
		System.out.println(u);
		session.commit();	//提交sql语句
		session.close();	//关闭Session
	}
	
	public void deleteById(int id) {	//按id号删除数据表中的数据
		session = sqlSessionFactory.openSession();	//打开Session
		int resultCount = session.delete("com.UserMapper.delete", id);//调用session中的delete方法
		session.commit();
		List<User> user_list = session.selectList("com.UserMapper.findAll");//显示数据表中所有的数据
		for(User u:user_list) {
			System.out.println(u);
		}
		session.commit();
		session.close();
		System.out.println("删除了的记录数:"+resultCount);
	}
	
	public void updateById(int id,String name,String sex) {	//更新数据
		session = sqlSessionFactory.openSession();			//打开Session
		User user = new User(id,name,sex);					//新建一个持久化类示例,用于记录要更新的信息
		int updateCount = session.update("com.UserMapper.update", user);	//调用session的update方法,并传入参数
		session.commit();									//提交
		
		List<User> user_list = session.selectList("com.UserMapper.findAll");	//查看数据表中左右的数据
		for(User u:user_list) {
			System.out.println(u);
		}
		session.commit();									//提交
		session.close();									//关闭Session
		System.out.println("更新了的记录数:"+updateCount);
	}
}

 

 

 

 

 

测试程序:

test.java:

 

package com;

import java.io.IOException;

public class Test {
	public static void main(String[] args) throws IOException {
		Operation op = new Operation();	//创建一个操作类
		op.init();						//调用init()初始化一下
		op.add("zje", "m");				//调用add()方法向数据库新增数据:name=“zje”,sex=“m”
	}
}

 

 

 

 

 

 

运行效果:

 

打开mysql,并用select * from tb_user 查询后,可以发现数据表中已经出现插入的信息。

 

 

(*)题外话:

log4j 日志功能的配置文件(xml文件):

从目录树中可以看到有一个 log4j.properties 的文件,内容如下:

 

log4j.rootLogger=ERROR,stdout
log4j.logger.com.UserMapper=DEBUG
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n


加上此文件后,可以在控制台中看到提交的 sql语句:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值