mybatis之第一个mybatis程序(一)
1、新建一个java项目,并在该项目下新建相应的目录以及文件: 其中lib文件夹下为依赖的jar包:mybatis.jar为mybatis依赖,mysql-connector-java.jar为连接mysql数据库依赖,log4j为打印日志依赖。 dtd文件夹中的dtd文件是为了在mybatis配置文件中按下"alt+/" 有标签提示,相关操作见前一篇。 config用来存储一些配置文件以及mapper,需要右键点击该文件夹,然后将该文件夹选择为Use as Source Folder db.properties为连接数据库的一些属性。 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 + "]"; } } 3、db.properties jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/mybatis jdbc.username=root jdbc.password=123456 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> 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" /> > 说明: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> 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(); } } } ? 该文件用于单元测试,测试配置是否成功。 (1)根据xml配置文件(全局配置文件)创建一个SqlSessionFactory对象 有数据源一些运行环境信息
(5)使用sql的唯一标志来告诉MyBatis执行哪个sql。sql都是保存在sql映射文件中的。 执行test方法为单元测试,在控制台输出: 说明Mybatis程序运行成功。需要注意的是数据库中的字段名和实体类中的要相对应。在数据库中为last_name,在mapper.xml文件中对其取名为lastName。? (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |