1、准备工作

jar包:

  mybatis-3.4.4.jar,下载地址:https://github.com/mybatis/ignite-cache/releases

  mysql-connector-java-5.1.40-bin.jar,下载地址:https://dev.mysql.com/downloads/connector/j/

项目目录结构:

数据库建标语句

/*如果已经存在此数据库,先删除*/
drop database if exists sqltest ;
/*创建并设置编码为UTF-8*/
create database sqltest default character set utf8 ;
/*选择数据库*/
use sqltest ; /*删除已有的学生表*/
drop table if exists tb_student ; /*创建学生表*/
CREATE TABLE `tb_student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`stuId` varchar(45) DEFAULT NULL,
`name` varchar(45) DEFAULT NULL,
`clsId` varchar(45) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; /*插入学生的数据*/
insert into tb_student (stuId,name,clsId) value ('','张三','') ;
insert into tb_student (stuId,name,clsId) value ('','李四','') ;
insert into tb_student (stuId,name,clsId) value ('','王五','') ;
insert into tb_student (stuId,name,clsId) value ('','赵六','') ;
insert into tb_student (stuId,name,clsId) value ('','巩发财','') ;
insert into tb_student (stuId,name,clsId) value ('','柏拉图','') ;
insert into tb_student (stuId,name,clsId) value ('','钱老虎','') ;
insert into tb_student (stuId,name,clsId) value ('','杨伟','') ;
insert into tb_student (stuId,name,clsId) value ('','陈海','') ;

二、代码编写

实体类Student:

package org.yoki.edu.main.vo;

public class Student {

    private Integer id;
private String stuId;
private String name;
private String clsId; /*省略setter、getter方法*/ }

MyBatis的配置文件:

<?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> <!-- typeAliases必须写在environments和mappers前面,不然报错,这是dtd格式限制的 -->
<typeAliases>
<!-- 用于在实体类的映射文件进行使用student,而不用每次使用类的全名 -->
<typeAlias type="org.yoki.edu.main.vo.Student" alias="student" />
</typeAliases> <environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<!-- 数据库链接信息,注:分号改为&amp;转义符,防止报错 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/sqltest?useUnicode=true&amp;characterEncoding=UTF-8&amp;useSSL=false" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments> <mappers>
<!-- 实体类的映射文件 -->
<mapper resource="org/yoki/edu/main/vo/StudentMapper.xml" />
</mappers> </configuration>

实体类Student配置文件:

<?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">
<!-- namespace随意内容 -->
<mapper namespace="this.is.student.mapper.namespace"> <!-- 方法一 -->
<!-- type属性对应与在MyBatis配置文件中typeAliases标签下定义的引用 -->
<resultMap id="studentMapper" type="student">
<!-- 属性名称<>列名 -->
<id property="id" column="id" />
<result property="stuId" column="stuId" />
<result property="name" column="name" />
<result property="clsId" column="clsId" />
</resultMap> <!-- resultMap属性值对应 -->
<select id="selectById" resultMap="studentMapper">
select * from tb_student where id = #{id}
</select> <!-- 方法二 -->
<!-- resultType可以使用类的全名,也可以使用MyBatis配置文件中typeAliases标签下定义的引用 -->
<!-- <select id="selectById" resultType="org.yoki.edu.main.vo.Student"> -->
<!-- select * from tb_student where id = #{id} -->
<!-- </select> --> </mapper>
SessionUtils(用于初始化SqlSessionFactory和提供获取SqlSession的接口):
package org.yoki.edu.utils;

import java.io.IOException;
import java.io.InputStream; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class SessionUtils { private static SqlSessionFactory fa = null ; static{
/*静态代码块,在类加载后执行*/
String resource = "org/yoki/edu/utils/mybatis-config.xml" ;
InputStream input;
try {
/*获取配置文件的输入流*/
input = Resources.getResourceAsStream(resource);
/*根据输入流生成SqlSessionFactory*/
fa = new SqlSessionFactoryBuilder().build(input) ;
int j = 0 ;
} catch (IOException e) {
e.printStackTrace();
}
} public SqlSession getSqlSession(){
if(null == fa)
return null;
SqlSession session = fa.openSession() ;
return session ;
} }

StudentDao(这里偷懒没有使用接口):

package org.yoki.edu.main.dao;

import org.apache.ibatis.session.SqlSession;
import org.yoki.edu.main.vo.Student;
import org.yoki.edu.utils.SessionUtils; public class StudentDao { private SessionUtils utils = new SessionUtils() ; public Student getById(Integer id){
SqlSession session = utils.getSqlSession() ;
/*selectOne的第一个参数对应映射文件的namespace + '.' + (select、update、insert、delete)id*/
Student st = session.selectOne("this.is.student.mapper.namespace" + ".selectById", id) ;
return st ;
} }

测试类:

package org.yoki.edu.main;

import org.yoki.edu.main.dao.StudentDao;
import org.yoki.edu.main.vo.Student; public class MainRun { public static void main(String[] args) {
StudentDao dao = new StudentDao() ;
Student st = dao.getById(2) ;
System.out.println(st);
} }

结果:

最新文章

  1. ping 或者ssh 发生connect: No buffer space available 错误
  2. linux中tar之解压和压缩常用
  3. windows10 下访问 virtualbox 虚拟机的linux15.10/16.04 系统 及 用 putty 访问虚拟机的配置
  4. arcgis破解的时候,不能启动license manager的问题
  5. JavaScript排序算法——插入排序
  6. 【jQuery 冻结任意行列】冻结任意行和列的jQuery插件
  7. JavaWeb高级:Servlet源码分析
  8. windows系统服务编程代码示例分享
  9. Json数据处理
  10. word2007如何进行批注
  11. leetcode 126. Word Ladder II ----- java
  12. 转载:js动态获取图片长宽尺寸(兼容所有浏览器,速度极快)
  13. 细雨学习笔记:Jmeter上一个请求的结果作为下一个请求的参数--使用正则提取器
  14. a different object with the same identifier value was already associated withthe session异常解决方案
  15. DNN学习
  16. Android开发视频学习(2)
  17. poj 3628 (搜索or背包)
  18. tomcat URL简写案例:模拟站点www.baidu.com的訪问
  19. Java中IO流
  20. Jquery EasyUI Base基础

热门文章

  1. formData使用总结
  2. 【python接口自动化】httpUtils
  3. 我要好offer之 网络大总结
  4. 快充 IC BQ25896 的 ICO (input current optimizer)
  5. SPI设备的驱动
  6. Servlet 2.4 规范之第三篇:Servlet生命周期
  7. Boost Asio介绍--之一
  8. Ural 1774 Barber of the Army of Mages 最大流
  9. 小R与手机
  10. jquery操作checkbox方法(全选、全不选、至少选择一个、选择值/文本)