1、新建一个java项目,并在该项目下新建相应的目录以及文件:
其中lib文件夹下为依赖的jar包:mybatis.jar为mybatis依赖,MysqL-connector-java.jar为连接MysqL数据库依赖,log4j为打印日志依赖。
dtd文件夹中的dtd文件是为了在mybatis配置文件中按下"alt+/" 有标签提示,相关操作见前一篇。
config用来存储一些配置文件以及mapper,需要右键点击该文件夹,然后将该文件夹选择为Use as Source Folder
log4j.xml为配置日志文件。
mybatis-config.xml为配置mybatis的文件。
2、Employee.java
package com.gong.mybatis.bean; public class Employee { private Integer id; String lastName; String gender; String email; public Integer getId() { return id; } void setId(Integer id) { this.id = String getLastName() { lastName; } setLastName(String lastName) { this.lastName = String getGender() { gender; } setGender(String gender) { this.gender = String getEmail() { email; } setEmail(String email) { this.email = email; } @Override String toString() { return "Employee [id=" + id + ",lastName=" + lastName + ",gender=" + gender + ",email=" + email + "]"; } }@H_502_90@
3、db.properties
jdbc.driver=com.MysqL.jdbc.Driver jdbc.url=jdbc:MysqL://localhost:3306/mybatis jdbc.username=root jdbc.password=123456@H_502_90@
4、log4j.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> appender name="STDOUT" class="org.apache.log4j.ConsoleAppender"> param ="Encoding" value="UTF-8" /> layout ="org.apache.log4j.PatternLayout"> ="ConversionPattern"="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n" </layout> appenderlogger ="java.sql"level value="debug" /> logger="org.apache.ibatis"="info" rootappender-ref ref="STDOUT" > log4j:configuration>@H_502_90@
5、mybatis-config.xml
DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"configurationproperties resource="db.properties"></propertiesenvironments default="development"> environment id> transactionManager type="JDBC" /> dataSource ="POOLED"> property ="driver"="${jdbc.driver}" /> ="url"="${jdbc.url}" ="username"="${jdbc.username}" ="password"="${jdbc.password}" dataSourceenvironmentenvironments<!-- 将我们写好的sql映射文件(EmployeeMapper.xml)一定要注册到全局配置文件(mybatis-config.xml)中 --> mappersmapper ="EmployeeMapper.xml" /> >@H_502_90@
说明:properties标签用于引入外部的一些配置。在environments中的dataSource下可配置连接数据库的一些信息,具体的value值可以使用$来获取外部资源的相关属性值。同时我们还要配置mapper文件,在该文件中主要是编写与sql相关的映射,其具体位置根据Mapper中的属性的不同会稍有不同,以后再单独写。
6、EmployeeMapper.xml
DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"namespace="com.gong.mybatis.EmployeeMapper" namespace:名称空间; id:唯一标识 resultType:返回值类型 #{id}:从传递过来的参数中取出id值 select ="getEmpById" resultType="com.gong.mybatis.bean.Employee"> select id,last_name lastName,email,gender from tbl_employee where id = #{id} selectmapper>@H_502_90@
select标签用于从数据库中查询数据,id为标识该查询语句的唯一标识,resultType为返回的结果。
7、在数据库中新建一个名为mybatis的数据库,然后新建一个tbl_employee表,相关信息如下:
8、TestMybatis.java
com.gong.mybatis.test; import java.io.IOException; java.io.InputStream; org.apache.ibatis.io.Resources; org.apache.ibatis.session.sqlSession; org.apache.ibatis.session.sqlSessionFactory; org.apache.ibatis.session.sqlSessionFactoryBuilder; org.junit.Test; com.gong.mybatis.bean.Employee; TestMybatis { @Test void test() throws IOException { String resource = "mybatis-config.xml"; InputStream is = Resources.getResourceAsStream(resource); sqlSessionFactory sqlSessionFactory = new sqlSessionFactoryBuilder().build(is); sqlSession openSession = sqlSessionFactory.openSession(); 获取sqlSession实例,能够直接执行已经映射好的sql语句 try { 返回值类型为Employee,方法为EmployeeMapper.xml中namespace的值加上id标识 Employee employee = openSession.selectOne("com.gong.mybatis.EmployeeMapper.getEmpById",1); System.out.println(employee); }finally { openSession.close(); } } }@H_502_90@
该文件用于单元测试,测试配置是否成功。
(1)根据xml配置文件(全局配置文件)创建一个sqlSessionFactory对象 有数据源一些运行环境信息
(2)sql映射文件;配置了每一个sql,以及sql的封装规则等。
(3)将sql映射文件注册在全局配置文件中
(4)写代码:
- 根据全局配置文件得到sqlSessionFactory;
- 使用sqlSession工厂,获取到sqlSession对象使用他来执行增删改查
- 一个sqlSession就是代表和数据库的一次会话,用完关闭
(5)使用sql的唯一标志来告诉MyBatis执行哪个sql。sql都是保存在sql映射文件中的。
说明Mybatis程序运行成功。需要注意的是数据库中的字段名和实体类中的要相对应。在数据库中为last_name,在mapper.xml文件中对其取名为lastName。