mybatis入门

  • 先举一个入门案例

1)创建一个mybatis-day01这么一个javaweb工程或java工程
2)导入mybatis和mysql/oracle的jar包到/WEB-INF/lib目录下
3)创建students.sql表

  1. --mysql语法
  2. create table students(
  3. id int(5) primary key,
  4. name varchar(10),
  5. sal double(8,2)
  6. );
  7. --oracle语法
  8. create table students(
  9. id number(5) primary key,
  10. name varchar2(10),
  11. sal number(8,2)
  12. );

4)创建Student.java

  1. /**
  2. * 学生
  3. * @author AdminTC
  4. */
  5. public class Student {
  6. private Integer id;
  7. private String name;
  8. private Double sal;
  9. public Student(){}
  10. public Integer getId() {
  11. return id;
  12. }
  13. public void setId(Integer id) {
  14. this.id = id;
  15. }
  16. public String getName() {
  17. return name;
  18. }
  19. public void setName(String name) {
  20. this.name = name;
  21. }
  22. public Double getSal() {
  23. return sal;
  24. }
  25. public void setSal(Double sal) {
  26. this.sal = sal;
  27. }
  28. }

5)在entity目录下创建StudentMapper.xml配置文件

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  4. <!-- namespace属性是名称空间,必须唯一(任意取即可,不一定要全路径名(只是为了在使用时方便使用student.getclass.getname获取全路径名从而防止写错)) -->
  5. <mapper namespace="cn.itcast.javaee.mybatis.app04.Student">
  6. <!-- resultMap标签:映射实体与表
  7. type属性:表示实体全路径名
  8. id属性:为实体与表的映射取一个任意的唯一的名字(在增删改查时,使用在resultMap中(使用后可以实体属性和表字段不一致))
  9. 在实体属性和表字段完全一样的情况下,一下resultMap代码块可以不写
  10. -->
  11. <resultMap type="student" id="studentMap">
  12. <!-- id标签:映射主键属性
  13. result标签:映射非主键属性
  14. property属性:实体的属性名
  15. column属性:表的字段名
  16. -->
  17. <id property="id" column="id"/>
  18. <result property="name" column="name"/>
  19. <result property="sal" column="sal"/>
  20. </resultMap>
  21. <!--
  22. insert标签:要书写insert这么一个sql语句
  23. (
  24. 增删改实际上看的是实际的sql语句,所以写insert还是update或者delete都行,推荐什么操作用什么标签
  25. 但是select必须用select标签
  26. )
  27. id属性:为insert这么一个sql语句取一个任意唯一的名字
  28. parameterType:要执行的dao中的方法的参数,如果是类的话,必须使用全路径类
  29. -->
  30. <insert id="add1">
  31. insert into students(id,name,sal) values(1,'哈哈',7000)
  32. </insert>
  33. <insert id="add2" parameterType="student">
  34. insert into students(id,name,sal) values(#{id},#{name},#{sal})
  35. </insert>
  36. <insert id="add3" parameterType="student">
  37. insert into students(id,name,sal) values(#{id},#{name},#{sal})
  38. </insert>
  39. </mapper>

6)在src目录下创建mybatis.xml配置文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  4. <configuration>
  5. <!-- 加载类路径下的属性文件(src下) -->
  6. <properties resource="db.properties"/>
  7. <!-- 设置类型别名(为了方便在映射文件中使用) -->
  8. <typeAliases>
  9. <typeAlias type="cn.itcast.javaee.mybatis.app04.Student" alias="student"/>
  10. </typeAliases>
  11. <!-- 设置一个默认的连接环境信息 默认的环境变量只能设置一个-->
  12. <environments default="mysql_developer">
  13. <!-- 连接环境信息,取一个任意唯一的名字 可以设置多个-->
  14. <environment id="mysql_developer">
  15. <!-- mybatis使用jdbc事务管理方式 -->
  16. <transactionManager type="jdbc"/>
  17. <!-- mybatis使用连接池方式来获取连接 -->
  18. <dataSource type="pooled">
  19. <!-- 配置与数据库交互的4个必要属性 通过${}获取在资源文件中配置的数据库信息-->
  20. <property name="driver" value="${mysql.driver}"/>
  21. <property name="url" value="${mysql.url}"/>
  22. <property name="username" value="${mysql.username}"/>
  23. <property name="password" value="${mysql.password}"/>
  24. </dataSource>
  25. </environment>
  26. <!-- 连接环境信息,取一个任意唯一的名字 -->
  27. <environment id="oracle_developer">
  28. <!-- mybatis使用jdbc事务管理方式 -->
  29. <transactionManager type="jdbc"/>
  30. <!-- mybatis使用连接池方式来获取连接 -->
  31. <dataSource type="pooled">
  32. <!-- 配置与数据库交互的4个必要属性 -->
  33. <property name="driver" value="${oracle.driver}"/>
  34. <property name="url" value="${oracle.url}"/>
  35. <property name="username" value="${oracle.username}"/>
  36. <property name="password" value="${oracle.password}"/>
  37. </dataSource>
  38. </environment>
  39. </environments>
  40. <!-- 加载映射文件-->
  41. <mappers>
  42. <mapper resource="cn/itcast/javaee/mybatis/app14/StudentMapper.xml"/>
  43. </mappers>
  44. </configuration>

7)在src下建立db.properties文件,保存数据库信息

  1. mysql.driver=com.mysql.jdbc.Driver
  2. mysql.url=jdbc:mysql://127.0.0.1:3306/mybatis
  3. mysql.username=root
  4. mysql.password=root
  5. oracle.driver=oracle.jdbc.driver.OracleDriver
  6. oracle.url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
  7. oracle.username=scott
  8. oracle.password=tiger

8)在util目录下创建MyBatisUtil.java类,并测试与数据库是否能连接

  1. /**
  2. * 工具类
  3. * 1)在静态初始化块中加载mybatis配置文件和StudentMapper.xml文件一次
  4. * 2)使用ThreadLocal对象让当前线程与SqlSession对象绑定在一起
  5. * 3)获取当前线程中的SqlSession对象,如果没有的话,从SqlSessionFactory对象中获取SqlSession对象
  6. * 4)获取当前线程中的SqlSession对象,再将其关闭,释放其占用的资源
  7. *
  8. */
  9. public class MybatisUtil {
  10. //将session与当前线程绑定(ThreadLocal将当前对象在每个线程独立的copy一份,防止多线程问题)
  11. private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();
  12. private static SqlSessionFactory sqlSessionFactory;
  13. /**
  14. * 加载位于src/mybatis.xml配置文件
  15. */
  16. static{
  17. try {
  18. Reader reader = Resources.getResourceAsReader("mybatis.xml");
  19. sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
  20. } catch (IOException e) {
  21. e.printStackTrace();
  22. throw new RuntimeException(e);
  23. }
  24. }
  25. /**
  26. * 禁止外界通过new方法创建
  27. */
  28. private MybatisUtil(){}
  29. /**
  30. * 获取SqlSession
  31. */
  32. public static SqlSession getSqlSession(){
  33. //从当前线程中获取SqlSession对象
  34. SqlSession sqlSession = threadLocal.get();
  35. //如果SqlSession对象为空
  36. if(sqlSession == null){
  37. //在SqlSessionFactory非空的情况下,获取SqlSession对象
  38. sqlSession = sqlSessionFactory.openSession();
  39. //将SqlSession对象与当前线程绑定在一起
  40. threadLocal.set(sqlSession);
  41. }
  42. //返回SqlSession对象
  43. return sqlSession;
  44. }
  45. /**
  46. * 关闭SqlSession与当前线程分开
  47. */
  48. public static void closeSqlSession(){
  49. //从当前线程中获取SqlSession对象
  50. SqlSession sqlSession = threadLocal.get();
  51. //如果SqlSession对象非空
  52. if(sqlSession != null){
  53. //关闭SqlSession对象
  54. sqlSession.close();
  55. //分开当前线程与SqlSession对象的关系,目的是让GC尽早回收
  56. threadLocal.remove();
  57. }
  58. }
  59. /**
  60. * 测试
  61. */
  62. public static void main(String[] args) {
  63. Connection conn = MybatisUtil.getSqlSession().getConnection();
  64. System.out.println(conn!=null?"连接成功":"连接失败");
  65. }
  66. }

9)在dao目录下创建StudentDao.java类并测试

  1. /**
  2. * 持久层
  3. * @author AdminTC
  4. */
  5. public class StudentDao {
  6. /**
  7. * 增加学生
  8. */
  9. public void add1() throws Exception{
  10. SqlSession sqlSession = null;
  11. try{
  12. sqlSession = MybatisUtil.getSqlSession();
  13. //事务开始(默认)
  14. //读取StudentMapper.xml映射文件中的SQL语句
  15. int i = sqlSession.insert("cn.itcast.javaee.mybatis.app04.Student.add1");
  16. System.out.println("本次操作影响了"+i+"行");
  17. //事务提交
  18. sqlSession.commit();
  19. }catch(Exception e){
  20. e.printStackTrace();
  21. //事务回滚
  22. sqlSession.rollback();
  23. throw e;
  24. }finally{
  25. MybatisUtil.closeSqlSession();
  26. }
  27. }
  28. /**
  29. * 增加学生
  30. */
  31. public void add2(Student student) throws Exception{
  32. SqlSession sqlSession = null;
  33. try{
  34. sqlSession = MybatisUtil.getSqlSession();
  35. //事务开始(默认)
  36. //读取StudentMapper.xml映射文件中的SQL语句
  37. sqlSession.insert(Student.class.getName()+".add2",student);
  38. //事务提交
  39. sqlSession.commit();
  40. }catch(Exception e){
  41. e.printStackTrace();
  42. //事务回滚
  43. sqlSession.rollback();
  44. throw e;
  45. }finally{
  46. MybatisUtil.closeSqlSession();
  47. }
  48. }
  49. /**
  50. * 增加学生
  51. */
  52. public void add3(Student student) throws Exception{
  53. SqlSession sqlSession = null;
  54. try{
  55. sqlSession = MybatisUtil.getSqlSession();
  56. sqlSession.insert(Student.class.getName()+".add3",student);
  57. sqlSession.commit();
  58. }catch(Exception e){
  59. e.printStackTrace();
  60. sqlSession.rollback();
  61. throw e;
  62. }finally{
  63. MybatisUtil.closeSqlSession();
  64. }
  65. }
  66. public static void main(String[] args) throws Exception{
  67. StudentDao dao = new StudentDao();
  68. dao.add1();
  69. dao.add2(new Student(2,"呵呵",8000D));
  70. dao.add3(new Student(3,"嘻嘻",9000D));
  71. dao.add3(new Student(4,"笨笨",9000D));
  72. }
  73. }

mybatis工作流程

1)通过Reader对象读取src目录下的mybatis.xml配置文件(该文本的位置和名字可任意)
2)通过SqlSessionFactoryBuilder对象创建SqlSessionFactory对象
3)从当前线程中获取SqlSession对象
4)事务开始,在mybatis中默认
5)通过SqlSession对象读取StudentMapper.xml映射文件中的操作编号,从而读取sql语句
6)事务提交,必写
7)关闭SqlSession对象,并且分开当前线程与SqlSession对象,让GC尽早回收

CURD操作

mybatis入门,基本案例和xml讲解的更多相关文章

  1. 02SpringMvc_springmvc快速入门小案例(XML版本)

    这篇文章中,我们要写一个入门案例,去整体了解整个SpringMVC. 先给出整个项目的结构图:

  2. MyBatis入门程序(基于XML配置)

    创建一个简单的MyBatis入门程序,实现对学生信息的增删改查功能(基于XML配置) 一.新建一个Java工程,导入MyBatis核心jar包.日志相关的jar包以及连接Oracle数据库所需驱动包, ...

  3. mybatis入门基础(三)----SqlMapConfig.xml全局配置文件解析

    一:SqlMapConfig.xml配置文件的内容和配置顺序如下 properties(属性) settings(全局配置参数) typeAiases(类型别名) typeHandlers(类型处理器 ...

  4. Mybatis笔记五:Mybatis的全局配置文件Configuration.xml讲解

    从 XML 中构建 SqlSessionFactory 每个基于Mybatis应用都是以一个SqlSessionFactory实例为中心.SqlSessionFactory实例可以由SqlSessio ...

  5. Mybatis 入门之resultMap与resultType讲解实例

    resultMap:适合使用返回值是自定义实体类的情况 resultType:适合使用返回值得数据类型是非自定义的,即jdk的提供的类型 resultMap : type:映射实体类的数据类型 id: ...

  6. Mybatis入门和简单Demo

    一.Mybatis的诞生 回顾下传统的数据库开发,JDBC和Hibernate是使用最普遍的技术,但这两种ORM框架都存在一定的局限性: JDBC:最原生的技术,简单易学,执行速度快,效率高,适合大数 ...

  7. MyBatis入门案例、增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

  8. MyBatis入门案例 增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

  9. Mybatis入门案例中设计模式的简单分析

    Talk is cheap, show me the code! public class TestMybatis { public static void main(String[] args) t ...

随机推荐

  1. php 编码规范(1)

    1. 包含尽量不要使用短标签例如 <? #coding ?> 2. 忽略结束标签,防止其他字符或者空格影响到代码 <?php$foo = 'foo'; 如果不开启压缩或者缓存输出时候 ...

  2. HashMap HashTable HashSet区别剖析

    HashMap.HashSet.HashTable之间的区别是Java程序员的一个常见面试题目,在此仅以此博客记录,并深入源代码进行分析: 在分析之前,先将其区别列于下面 1:HashSet底层采用的 ...

  3. Selenium IDE测试

    判断WEB程序是否能打开页面,并且打开了正确的页面,可以通过 assertTitle和assertLocation进行判断 并且这些操作不需要提供value. target就是期望的URL和页面标题, ...

  4. android popupwindow低版本报空指针

    在项目中使用Popupwindow pop=new Popupwindow();在2.3版本报 异常信息: Exception: null 堆栈信息: android.widget.PopupWind ...

  5. 转:支撑Github的开源技术

    原文来自于:http://www.infoq.com/cn/news/2014/03/projects-power-github Github在3月19号开放了新的项目展示页面(Showcase),S ...

  6. PHP 之isset() 与 unset()

    isset()用来判断某个变量是否已经被声明,他返回一个boolean类型的值,如果声明则返回true否则返回false.如果变量被声明后,给他赋值为NULL,他也返回false. 如: <?p ...

  7. 【转】Android 带checkbox的listView 实现多选,全选,反选----解决checkbox错位问题

    原文网址:http://blog.csdn.net/onlyonecoder/article/details/8687811 Demo地址(0分资源):http://download.csdn.net ...

  8. Cookie和Session(转)

    会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...

  9. 抓取“矢量”的实时交通流量数据

    1. 引言 最近老师有一个需求,就是想要抓取实时的矢量交通流量数据来做分析,类似于百度地图,高德地图的"实时路况"那种.平时的网络抓取工作一般是抓取网页上现成的数据,但是交通流量数 ...

  10. 我所理解的设计模式(C++实现)——策略模式(Strategy Pattern)

    概述: 每个人都要“交个人所得税”,但是“在美国交个人所得税”和“在中国交个人所得税”就有不同的算税方法. 而策略模式就是对算法进行包装,是把使用算法的责任和算法本身分割开来,委派给不同的对象管理.策 ...