热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

myBatis入门(二)-mybatis工作流程

myBatis工作流程我们通过一个向数据库中插入一条数据记录的例子来了解一些myBatis的工作流程下面这个demo看下src下文件目录结构数据库表

myBatis工作流程

我们通过一个向数据库中插入一条数据记录的例子来了解一些myBatis的工作流程

  • 下面这个demo看下src下文件目录结构

这里写图片描述

  • 数据库表的描述如下,创建脚本很简单,这里就不写了
    这里写图片描述

下面开始写代码

第一步:写数据表对应的实体类Student.java

  package com.cxspace.bean;

public class Student {

    private int id;

    private String s_name;

    private int s_age;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getS_name() {
        return s_name;
    }

    public void setS_name(String s_name) {
        this.s_name = s_name;
    }

    public int getS_age() {
        return s_age;
    }

    public void setS_age(int s_age) {
        this.s_age = s_age;
    }

    @Override
    public String toString() {
        return "Student [id=" + id + ", s_name=" + s_name + ", s_age=" + s_age
                + "]";
    }

    public Student(int id, String s_name, int s_age) {
        super();
        this.id = id;
        this.s_name = s_name;
        this.s_age = s_age;
    }

    public Student(){

    }

}

第二步:写实体类的映射配置文件StudentMapper.xml









<mapper namespace="com.cxspace.bean.Student">


    

  

  

  <insert id="addStudent" parameterType="com.cxspace.bean.Student">
      insert into student values (#{id},#{s_name},#{s_age})
  insert>


mapper>
  • 在里面我们配置了一条向数据库插入数据记录的sql语句,并用ognl表达式把java代码中对象的值传入语句。

第三步:写总的配置文件Configuration.xml文件





<configuration>

  <environments default="mysql_development">
   
    <environment id="mysql_development">

    
      <transactionManager type="JDBC">
        <property name="" value=""/>
      transactionManager>

      
      <dataSource type="POOLED">

        
        <property name="driver" value="com.mysql.jdbc.Driver"/>

        <property name="url" value="jdbc:mysql://127.0.0.1:3306/mybatis"/>

        <property name="username" value="root"/>

        <property name="password" value="root"/>

      dataSource>
    environment>
  environments>

<mappers>
   <mapper resource="com/cxspace/bean/StudentMapper.xml"/>
mappers>
configuration>

第四步:写mybatis工具类,维护数据库连接

package com.cxspace.db;

import java.io.IOException;
import java.io.Reader;
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 MyBatisUtil {

     private static ThreadLocal threadLocal = new ThreadLocal();
     private static SqlSessionFactory sqlSessionFactory;

     //加载Configuration.xml配置文件
     static{
         try {

             Reader reader = Resources.getResourceAsReader("com/cxspace/config/Configuration.xml");

             sqlSessiOnFactory= new SqlSessionFactoryBuilder().build(reader);


        } catch (IOException e) {

             e.printStackTrace();
        }
     }

     /* * 禁止外部new来调用 */
     private MyBatisUtil(){

     }

     /* * 获取SqlSession */
     public static SqlSession getSqlSession(){

         //从当前线程中获取SqlSession对象
         SqlSession sqlSession = threadLocal.get();

         //如果SqlSession为空
         if (sqlSession == null) {

             //在SqlSessionFactory非空的情况下,获取SqlSession对象
             sqlSession = sqlSessionFactory.openSession();
             //将SqlSession对象与当前线程绑定在一起
             threadLocal.set(sqlSession);
        }

         //返回SqlSession对象
         return sqlSession;
     }

     /* * 关闭SqlSession与当前线程分开 */
     public static void closeSqlSession(){

         //从当前线程中获取SqlSession对象
         SqlSession sqlSession = threadLocal.get();

         //如果SqlSession对象非空
         if (sqlSession != null) {
             //关闭
            sqlSession.close();
            //放开当前线程与SqlSession对象的关系,让GC尽快回收
            threadLocal.remove();

        }

     }

}

第五步:写StudentDao.java 对数据具体操作

  package com.cxspace.dao;

import java.util.List;

import javax.jms.Message;

import org.apache.ibatis.session.SqlSession;

import com.cxspace.bean.Student;
import com.cxspace.db.MyBatisUtil;


public class StudentDao {

    /* * 增加学生 */
    public void add(Student student) throws Exception{

        SqlSession sqlSession = null;

        try {

            sqlSession = MyBatisUtil.getSqlSession();

            //事务开始(默认就开始了)
            //读取StdentMapper.xml配置的SQL语句

            int i = sqlSession.insert("com.cxspace.bean.Student.addStudent",student);

            System.out.println("这次操作影响了:"+i+"行");

            //事务提交

            sqlSession.commit();

        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
            //事务回滚
            sqlSession.rollback();
            throw(e);
        }finally{
            MyBatisUtil.closeSqlSession();
        }

    }

}

第六步:测试

 package com.cxspace.test;

import com.cxspace.bean.Student;
import com.cxspace.dao.StudentDao;

public class TestCRUD {

    public static void main(String[] args) throws Exception {


        StudentDao studentDao = new StudentDao();

        Student student = new Student();

        student.setId(666);
        student.setS_name("xyz");
        student.setS_age(29);

        studentDao.add(student);

    }

}

最后测试结果

控制台
这里写图片描述

数据库
这里写图片描述

最后,让我们对整个流程做一个总结,看看执行这样一条语句,mybatis做了什么。
这里写图片描述

  • 附上:数据库事务的理论解释
数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性、一致性、隔离性和持久性)属性。事务是数据库运行中的一个逻辑工作单位,由DBMS中的事务管理子系统负责事务的处理。

推荐阅读
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • 本文介绍了Sencha Touch的学习使用心得,主要包括搭建项目框架的过程。作者强调了使用MVC模式的重要性,并提供了一个干净的引用示例。文章还介绍了Index.html页面的作用,以及如何通过链接样式表来改变全局风格。 ... [详细]
author-avatar
usx7054252
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有