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语句: