MyBatis框架01(委婉待续)

1. MyBatis框架的简单介绍

  • 是一个基于java的持久层框架,内部封装 了JDBC,是开发者只需要关关注于sql语句本身。
  • 通过xml配置文件或者注解的方式,将各种要执行的statement配置起来,并通过java对象,和Sql中的动态参数进行映射生成最终的sql语句。最后由mybatis框架执行sql语句,并将结果映射为java对象,并返回。
  • 采用了ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了底层的细节。
    ORM: Object Relational Mapping 关系对象映射。
    简单的说,就是把数据库表和实体类及实体的属性对应起来,让我们操作实体类就可以实现操作数据库表。
userUser
iduserid
usernameuserName

2. 以前JDBC的分析

public static void main(String[] args) {
    
    Connection connection = null;
    PreparedStatement preparedStatement = null;
    ResultSet resultSet = null;
    
    try {
        //1. 加载驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2. 获得链接
        connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/database", "username", "password"); 
        //3. 创建statement
        String sql = "select * from user where id = ? and username = ?";
        preparedStatement = connection.prepareStatement(sql);
        preparedStatement.setString(1, "王五");
  		// 4. 执行statement
        resultSet = preparedStatement.executeQuery();
        // 5. 遍历结果
        while (resultSet.next()) {
        	System.out.println(resultSet.getString("id") + "" + resultSet.getString("username"));
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        // 6. 释放资源
        if (resultSet != null) {
            try {resultSet.close(); } catch (SQLException e) {e.printStackTrace(); } 
        }
        if (preparedStatement != null) {
            try {preparedStatement.close(); } catch (SQLException e) {e.printStackTrace(); } 
        }
        if (connection != null) {
            try {connection.close(); } catch (SQLException e) {e.printStackTrace(); } 
        }
    }
}

存在的问题:

  1. 频繁的创建数据库连接的操作,会影响性能。----------->数据库连接池
  2. sql语句硬编码进java代码中了,改变sql语句需要改变java代码。------------->将sql 语句写进配置文件中或者使用注解。
  3. 查询的结果集解析过程复杂,而且硬编码进java代码中了------------.>将数据库记录封装进pojo对象。

3.MyBatis 的环境搭建

  1. 创建maven工程并导入坐标。
<packaging>jar</packaging>
<dependencies>
	<dependency>
		<groupId>org.mybatis</groupId>
		<artifactId>mybatis</artifactId>
		<version>3.4.5</version>
	</dependency>
    
	<dependency>
		<groupId>junit</groupId>
		<artifactId>junit</artifactId>
		<version>4.10</version>
		<scope>test</scope>
	</dependency>
    
	<dependency>
		<groupId>mysql</groupId>
		<artifactId>mysql-connector-java</artifactId>
		<version>5.1.6</version>
		<scope>runtime</scope>
	</dependency>
    
	<dependency>
		<groupId>log4j</groupId>
		<artifactId>log4j</artifactId>
		<version>1.2.12</version>
	</dependency>
</dependencies>
  1. 在resources目录下,创建log4j的配置文件log4j.properties
# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE            debug   info   warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE

# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE

# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n
  1. 创建实体类和dao的接口

实体类:

package cn.maoritian.domain;

public class User implements Serializable {

    // 属性名和数据库表字段名严格相同
	private Integer id;
	private String username;
	private Date birthday;
	private String sex;
	private String address;

    // 各属性的 set 和 get 方法
	public Integer getId() {return id; }
	public void setId(Integer id) {this.id = id; }
	public String getUsername() {return username; }
	public void setUsername(String username) {this.username = username; }
	public Date getBirthday() {return birthday; }
	public void setBirthday(Date birthday) {this.birthday = birthday; }
	public String getSex() {return sex; }
	public void setSex(String sex) {this.sex = sex; }
	public String getAddress() {return address; }
	public void setAddress(String address) {this.address = address; }

    // toString()方法
	@Override
	public String toString() {
		return "User{" + "id=" + id + ", username='" + username + '\'' + ", birthday=" + birthday + ", sex='" + sex + '\'' + ", address='" + address + '\'' + '}';
	}
}

User 接口

package cn.maoritian.dao;

// 持久层接口
public interface IUserDao {

    // 返回所有用户列表
    List<User> findAll();
}
  • 注意:
    * 实体类需要实现序列化接口。
    * 在入门程序中,我们要求实体类中属性名和数据库表中的字段名完全相同!!

4.MyBatis的入门案例(一):使用xml配置sql语句

  1. 数据库表的准备
DROP TABLE IF EXISTS `users`;

CREATE TABLE `users` (
  `id` int(11) NOT NULL auto_increment,
  `username` varchar(32) NOT NULL COMMENT '用户名称',
  `birthday` datetime default NULL COMMENT '生日',
  `sex` char(1) default NULL COMMENT '性别',
  `address` varchar(256) default NULL COMMENT '地址',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

insert  into `users`(`id`,`username`,`birthday`,`sex`,`address`) values (41,'老王','2018-02-27 17:47:08','男','北京'),(43,'小二王','2018-03-04 11:34:34','女','北京金燕龙'),(45,'传智播客','2018-03-04 12:04:06','男','北京金燕龙'),(46,'老王','2018-03-07 17:37:26','男','北京'),(48,'小马宝莉','2018-03-08 11:44:00','女','北京修正');
  1. 在resources目录下创建mybatis的配置文件。SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8"?>
<!-- 引入Mybatis的xml约束 -->
<!DOCTYPE configuration
	PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
	"http://mybatis.org/dtd/mybatis-3-config.dtd">

<!-- mybatis的主配置文件 -->
<configuration>
    
	<!-- 配置环境,默认使用id为mysql的那套环境配置 -->
	<environments default="mysql">	
        
        <!-- 配置id为mysql的环境配置 -->
		<environment id="mysql">
			<!-- 配置事务的类型 -->
			<transactionManager type="JDBC"></transactionManager>
			<!-- 配置数据源(连接池) -->
			<dataSource type="POOLED">
				<!-- 连接数据库的4个基本信息 -->
				<property name="driver" value="com.mysql.jdbc.Driver"/>
				<property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/>
				<property name="username" value="root"/>
				<property name="password" value="123456"/>
			</dataSource>
		</environment>
        
	</environments>
    
</configuration>
  1. 映射配置文件.
    让mybatis框架通过反射机制给我们提供持久层接口的实现类。
    • 配置持久层接口的sql语句
      *映射配置文件的位置与其对应的接口的位置完全相同。只不过一个在crc下,一个在resources下。
      * 使用标签配置实现的接口,
      * 标签配置查询的方法。
      * 表明将查询的结果封装到哪个类中。
<?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">

<!-- 编写实现持久层代码的sql语句,namespace属性为其实现的持久层接口名 -->
<mapper namespace="cn.maoritian.dao.IUserDao">
    <!-- id属性为实现的方法,resultType属性为查询结果包装成的pojo类名 -->
    <select id="findAll" resultType="cn.maoritian.domain.User">
    	<!-- 在select标签内写sql语句 -->
        select * from user
    </select>
</mapper>
  • 注意:
    * namespace属性后面跟的是全限定类名(包名+类名)
    * mybatis的映射配置文件,必须和dao的接口的包结构相同
    * sql语句千万别再末尾加分号
  1. 在配置文件中,还需要配置映射文件的位置。mappers节点与environment同级。
<mappers>
    <!-- 每个持久层接口配置在一个单独的文件内 -->
    <mapper resource="cn/maoritian/dao/IUserDao.xml"/>
</mappers>
  1. 准备完毕,开始测试。
package cn.maoritian.dao.impl;

public class MybatisTest {

    public static void main(String[] args) throws Exception {
        // 1.读取配置文件,生成字节输入流
        InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
        // 2.创建SqlSessionFactory工厂
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        SqlSessionFactory factory = builder.build(in);
        // 3.使用工厂生产SqlSession对象
        SqlSession session = factory.openSession();
        // 4.使用SqlSession创建Dao接口的代理对象
        IUserDao userDao = session.getMapper(IUserDao.class);
        // 5.使用代理对象执行方法
        List<User> users = userDao.findAll();
        for (User user : users) {
            System.out.println(user);
        }
        // 6.释放资源
        session.close();
        config.close();
    }
}

测试的正确结果:

User{id=41, username='老王', birthday=Tue Feb 27 17:47:08 CST 2018, sex='男', address='北京'}
User{id=42, username='小二王', birthday=Fri Mar 02 15:09:37 CST 2018, sex='女', address='北京金燕龙'}
User{id=45, username='传智播客', birthday=Sun Mar 04 12:04:06 CST 2018, sex='男', address='北京金燕龙'}
User{id=46, username='老王', birthday=Wed Mar 07 17:37:26 CST 2018, sex='男', address='北京'}
User{id=48, username='小马宝莉', birthday=Thu Mar 08 11:44:00 CST 2018, sex='女', address='北京修正'}

5.MyBatis的入门案例(一):使用注解配置sql语句

将sql 语句写在持久层的注解中,数据库结构和测试代码均与上个案例相同.我们只要修改持久层接口IUserDao和Mybatis配置文件即可。

  1. 在持久层接口上,使用@select注解,
package cn.maoritian.dao;

// 持久层接口
public interface IUserDao {

    // 返回所有用户列表
    @Select("select * from users")
    List<User> findAll();
}

  1. mybatis 的主配置文件SqlMapConfig.xml,中mapper,如下:
<mappers>
    <mapper class="cn.maoritian.dao.IUserDao"/>
</mappers>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值