01_Mybatis入门

一. Mybatis介绍

1. MyBatis是一款优秀的持久层框架, 它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生信息, 将接口和Java的POJO(Plain Ordinary Java Object, Java实体类)映射成数据库中的记录。

2. Mybatis是面向sql的持久层框架, 他封装了jdbc访问数据库的过程, 我们开发, 只需专注于sql语句本身的拼装, 其它复杂的过程全部可以交给mybatis去完成。

二. Mybatis的使用

1. Mybatis的jar包

2. 在SqlMapConfig.xml配置文件中配置数据库环境

3. 在SqlMapConfig.xml配置文件中引入映射文件

4. 在UserMapper.xml映射文件中配置命名空间

5. 在UserMapper.xml映射文件中书写Sql

6. Mysql自增返回配置方式一

7. Mysql自增返回配置方式二

8. Mybatis查询数据库代码

9. Mybatis插入数据库代码, 需要主动提交(修改数据库都需要主动提交)

三. Mybatis入门例子

1. 新建一个名为MybatisRuMen的Java工程, 拷入相关jar包

2. 新建User.java

package com.lywgames.domain;

import java.util.Date;

public class User {
	private Integer id;
	private String name;
	private String sex;
	private Date birthday;
	private String address;

	public User() {	}
	
	public User(String name, String sex, Date birthday, String address) {
		this.name = name;
		this.sex = sex;
		this.birthday = birthday;
		this.address = address;
	}

	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;
	}

	public Date getBirthday() {
		return birthday;
	}

	public void setBirthday(Date birthday) {
		this.birthday = birthday;
	}

	public String getAddress() {
		return address;
	}

	public void setAddress(String address) {
		this.address = address;
	}

	@Override
	public String toString() {
		return "User [id=" + id + ", name=" + name + ", sex=" + sex + ", birthday=" + birthday + ", address=" + address
				+ "]";
	}

}

3. 在src目录下新建UserMapper.xml映射文件

4. 在src目录下新建SqlMapConfig.xml数据库配置文件

5. 新建Test.java

package com.lywgames;

import java.io.InputStream;
import java.util.Date;
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;
import com.lywgames.domain.User;

public class Test {
	public static void main(String[] args) {
		SqlSession sqlSession = null;
		try {
			// 指定全局配置文件
			String resource = "SqlMapConfig.xml";
			// 读取配置文件
			InputStream inputStream = Resources.getResourceAsStream(resource);
			// 构建sqlSessionFactory
			SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
			// 获取sqlSession
			sqlSession = sqlSessionFactory.openSession();

			// 第一个参数: 指定statement, 命名空间+"."+statementId
			// 第二个参数: 指定传入sql的参数
			User insertUser = new User("李卫", "男", new Date(System.currentTimeMillis()), "河南省郑州市");
			int result = sqlSession.insert("com.lywgames.domain.User.insertUser2", insertUser);
			System.out.println("插入操作影响行数:" + result);
			System.out.println(insertUser);
			// 写操作, 需要提交事务。
			sqlSession.commit();
			
			List<User> users = sqlSession.selectList("com.lywgames.domain.User.selectUser", "李");
			for (User user : users) {
				System.out.println(user);
			}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			if(sqlSession != null) {
				// 释放资源
				sqlSession.close();
			}
		}
	}
}

6. 查看user表数据

7. 运行项目

8. 运行项目后查看user表数据

四. Mybatis架构图

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值