热门关键字:
jquery > jquery教程 > html5 > mybatis学习一

mybatis学习一

243
作者:管理员
发布时间:2020/3/25 10:49:58
评论数:0
转载请自觉注明原文:http://www.jq-school.com/Show.aspx?id=1101

  mybatis学习一

  mybatis是一个支持普通SQL查询、存储过程和高级映射的优秀持久层框架。Mybatis可以使用简单的XML或注解进行配置和原始映射。以将接口和java的pojo映射成数据库中的记录

  mybatis框架图

  mybatis代码demo

  依赖包

  <dependency>

  <groupId>org.mybatis</groupId>

  <artifactId>mybatis</artifactId>

  <version>3.4.6</version>

  </dependency>

  <dependency>

  <groupId>mysql</groupId>

  <artifactId>mysql-connector-java</artifactId>

  <version>5.1.42</version>

  </dependency>

  <dependency>

  <groupId>log4j</groupId>

  <artifactId>log4j</artifactId>

  <version>1.2.17</version>

  </dependency>

  数据库创建语句

  CREATEDATABASEmybatis;

  USEmybatis;

  CREATETABLET_USER(

  IDINT(11)PRIMARYKEYAUTO_INCREMENT,

  NAMEVARCHAR(20)DEFAULTNULL,

  SEXCHAR(2)DEFAULTNULL;

  AGEINT(11)DEFAULTNULL

  )

  mybatis-config.xml

  <?xmlversion="1.0"encoding="UTF-8"?>

  <!DOCTYPEconfiguration

  PUBLIC"-//mybatis.org//DTDConfig3.0//EN"

  "http://mybatis.org/dtd/mybatis-3-config.dtd">

  <!--XML配置文件包含对MyBatis系统的核心设置-->

  <configuration>

  <!--指定MyBatis所用日志的具体实现-->

  <settings>

  <settingname="logImpl"value="LOG4J"/>

  </settings>

  <environmentsdefault="mysql">

  <!--环境配置,即连接的数据库。-->

  <environmentid="mysql">

  <!--指定事务管理类型,type="JDBC"指直接简单使用了JDBC的提交和回滚设置-->

  <transactionManagertype="JDBC"/>

  <!--dataSource指数据源配置,POOLED是JDBC连接对象的数据源连接池的实现。-->

  <dataSourcetype="POOLED">

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

  <propertyname="url"value="jdbc:mysql://192.168.47.151:3306/mybatis"/>

  <propertyname="username"value="root"/>

  <propertyname="password"value="root"/>

  </dataSource>

  </environment>

  </environments>

  <!--mappers告诉了MyBatis去哪里找持久化类的映射文件-->

  <mappers>

  <mapperresource="mapper/UserMapper.xml"/>

  </mappers>

  </configuration>

  UserMapper.xml

  <?xmlversion="1.0"encoding="UTF-8"?>

  <!DOCTYPEmapperPUBLIC"-//mybatis.org//DTDMapper3.0//EN"

  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

  <!--namespace指用户自定义的命名空间。-->

  <mappernamespace="mapper.UserMapper">

  <!--

  id="save"是唯一的标示符

  parameterType属性指明插入时使用的参数类型

  useGeneratedKeys="true"表示使用数据库的自动增长策略

  -->

  <insertid="save"parameterType="com.rookie.bigdata.domain.User"useGeneratedKeys="true">

  INSERTINTOT_USER(name,sex,age)

  VALUES(#{name},#{sex},#{age})

  </insert>

  </mapper>

  Mybatis.java

  publicstaticvoidmain(String[]args)throwsIOException{

  //读取mybatis-config.xml文件

  InputStreaminputStream=Resources.getResourceAsStream("mybatis-config.xml");

  //初始化mybatis,创建SqlSessionFactory类的实例

  SqlSessionFactorysqlSessionFactory=newSqlSessionFactoryBuilder()

  .build(inputStream);

  //创建Session实例

  SqlSessionsession=sqlSessionFactory.openSession();

  //创建User对象

  Useruser=newUser("张三","男",26);

  //插入数据

  session.insert("mapper.UserMapper.save",user);

  //提交事务

  session.commit();

  //关闭Session

  session.close();

  }

  User.java

  publicclassUserimplementsSerializable{

  //用户标识

  privateIntegerid;

  //用户姓名

  privateStringname;

  //用户性别

  privateStringsex;

  //用户年龄

  privateIntegerage;

  }

  至此保存数据成功

  mybatis的执行流程:

  1)调用SqlSessionFactoryBuilder对象的Build(inputStream)方法

  2)SqlSessionFactoryBuilder会根据输入流inputStream等信息创建XMLConfigBuilder对象

  3)SqlSessionFactoryBuilder调用XMLConfigBuilder对象的parse()方法

  4)SqlSessionFactoryBuilder对象解析XML配置文件返回Configuration对象

  5)SqlSessionFactoryBuilder根据Configuration对象创建一个DefaultSessionFactory对象

  6)SqlSessionFactoryBuilder返回DefaultSessionFactory对象给客户端,供客户端使用

  mybatis的核心类

  SqlSessionFactoryBuilder:SqlSessionFactoryBuilder有五个build()方法,每一种都允许你从不同的资源中创建一个SqlSessionFactory实例

  SqlSessionFactory:SqlSessionFactory是MyBatis的关键对象,它是个单个数据库映射关系经过编译后的内存镜像.SqlSessionFactory对象的实例可以通过SqlSessionFactoryBuilder对象类获得,而SqlSessionFactoryBuilder则可以从XML配置文件或一个预先定制的Configuration的实例构建出SqlSessionFactory的实例.每一个MyBatis的应用程序都以一个SqlSessionFactory对象的实例为核心.同时SqlSessionFactory也是线程安全的,SqlSessionFactory一旦被创建,应该在应用执行期间都存在.在应用运行期间不要重复创建多次,建议使用单例模式.SqlSessionFactory是创建SqlSession的工厂

  SqlSession:SqlSession是MyBatis的关键对象,是执行持久化操作的独享,类似于JDBC中的Connection.它是应用程序与持久层之间执行交互操作的一个单线程对象,也是MyBatis执行持久化操作的关键对象.SqlSession对象完全包含以数据库为背景的所有执行SQL操作的方法,它的底层封装了JDBC连接,可以用SqlSession实例来直接执行被映射的SQL语句.每个线程都应该有它自己的SqlSession实例.SqlSession的实例不能被共享,同时SqlSession也是线程不安全的,绝对不能讲SqlSeesion实例的引用放在一个类的静态字段甚至是实例字段中.也绝不能将SqlSession实例的引用放在任何类型的管理范围中,比如Servlet当中的HttpSession对象中.使用完SqlSeesion之后关闭Session很重要,应该确保使用finally块来关闭它.





如果您觉得本文的内容对您的学习有所帮助:支付鼓励



关键字:html
友荐云推荐