欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
  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块来关闭它.

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/html/h56865.shtml