首页 mybatis框架入门测试

mybatis框架入门测试

淚 · 彦 2018-9-1 0 485

简介:

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis,实质上Mybatisibatis进行一些改进。

MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。

Mybatis通过xml或注解的方式将要执行的各种statementstatementpreparedStatemntCallableStatement)配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回。

mybatis架构原理:

       mybatis是一个持久层的框架,是apache下的顶级项目。

       mybatis托管到goolecode下,再后来托管到github(https://github.com/mybatis/mybatis-3/releases)

       mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成(半自动化,大部分需要程序员编写sql)满足需要sql语句。

       mybatis可以将向 preparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象。(输出映射)

QQ图片20180901213203.png

         问题:

1】mysql-connection-java的版本不符,数据库连接出现问题,应用5.1.7版本;

2】#{}${}
#{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,自动进行java类型和jdbc类型转换,#{}可以有效防止sql注入。#{}可以接收简单类型值或pojo属性值。 如果parameterType传输单个简单类型值,#{}括号中可以是value或其它名称。

${}表示拼接sql串,通过${}可以将parameterType 传入的内容拼接在sql中且不进行jdbc类型转换,${}可以接收简单类型值或pojo属性值,如果parameterType传输单个简单类型值,${}括号中只能是value


3】项目环境配置及测试:建项目,导jar包

1、日志文件:导jar包

               位置:放在source folder(源文件夹)config下,名为log4j.properties;

               配置信息:log4j.rootLogger=DEBUG, A       <--debug级别,命名为A-->

                              log4j.appender.A=org.apache.log4j.ConsoleAppender
                              log4j.appender.A.layout=org.apache.log4j.PatternLayout      <--输出位置为控制台-->
                              log4j.appender.A.layout.ConversionPattern=%5p [%t] - %m%n       <--定义输出格式-->

2、SqlMapConfig.xml文件,mybatis项目的核心配置文件,用来加载sqlsessionfactory。置于source folder下的config下。

<?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>
	<!-- 和spring整合后 environments配置将废除-->
	<environments default="development">
		<environment id="development">
		<!-- 使用jdbc事务管理-->
			<transactionManager type="JDBC" />
		<!-- 数据库连接池-->
			<dataSource type="POOLED">
				<property name="driver" 
				value="com.mysql.jdbc.Driver" />
				<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
				<property name="username" value="root" />
				<property name="password" value="123456" />
			</dataSource>
		</environment>
	</environments>
<!-- 加载映射文件,必须放在configurition里面-->
	<mappers>
		<mapper resource="Users.xml"/> 		
	</mappers>	
</configuration>


3、配置Users.xml,置于source folder下的config下。其中namespace 为命名空间,对应于pojo实体类。id对应于测试方法的第一个参数,parameterType为测试方法第二个参数的类型,resultType为测试方法返回类型。标签对应执行的sql语句。


<?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="mapper.User">
<!-- 根据id获取用户信息 -->
	<select id="findUserById" parameterType="int" resultType="mapper.User">
		select * from user where id = #{id}
	</select>
	<!-- 自定义条件查询用户列表 -->
	<select id="findUserByUsername" parameterType="java.lang.String" 
			resultType="mapper.User">
	   select * from user where username like '%${value}%' 
	</select>
</mapper>
4、pojo实体类,置于src的mapper包下,名为User.java。对应于数据库表的字段。
package mapper;
import java.sql.Date;
public class User {
	private int id;
	private String username;// 用户姓名
	private String sex;// 性别
	private Date birthday;// 生日
	private String address;// 地址
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	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;
	}
	public String toString() {
		return "User [id=" + id + ", username=" + username + ", sex=" + sex
				+ ", birthday=" + birthday + ", address=" + address + "]";
	}
}
5、测试类,src的mybatis包下的Mybatis_Test.java
package mybatis;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import mapper.User;
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 org.junit.Test;

public class Mybatis_Test {
	public static SqlSessionFactory createSqlSessionFactory()  {
		// 配置文件
		String resource = "SqlMapConfig.xml";
		InputStream inputStream = null;
		try {
			inputStream = Resources.getResourceAsStream(resource);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		// 使用SqlSessionFactoryBuilder从xml配置文件中创建SqlSessionFactory
		SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
				.build(inputStream);
		return sqlSessionFactory;
	}
	SqlSessionFactory sqlSessionFactory= Mybatis_Test.createSqlSessionFactory();
	// 根据 id查询用户信息
	@Test
	public void findUserById() {
		// 数据库会话实例
		SqlSession sqlSession =null;
		try {
			// 创建数据库会话实例sqlSession
		sqlSession = sqlSessionFactory.openSession();
			// 查询单个记录,根据用户id查询用户信息
			User user = sqlSession.selectOne("findUserById", 10);
			// 输出用户信息
			System.out.println(user);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			if (sqlSession != null) {
				sqlSession.close();
			}
		}

	}

	// 根据用户名称模糊查询用户信息
	@Test
	public void findUserByUsername() {
		// 数据库会话实例
		SqlSession sqlSession = null;
		try {
			// 创建数据库会话实例sqlSession
			sqlSession = sqlSessionFactory.openSession();
			// 查询单个记录,根据用户id查询用户信息
			List<User> list = sqlSession.selectList("findUserByUsername", "张");
			System.out.println(list.size());
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			if (sqlSession != null) {
				sqlSession.close();
			}
		}
	}	
}


     



分享本文至:
免责声明:本文仅代表作者个人观点,与本网站无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
作者: 淚 · 彦 本文最后编辑于2018-9-1 04:33:01
淚 · 彦

若一切皆善,便一切皆美

作者的微博

发表评论: