原始jdbc操作

     //1. 导入驱动jar包//2.注册驱动Class.forName("com.mysql.jdbc.Driver");//3.获取数据库连接对象Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db", "root", "root");//4.定义sql语句String sql = "update account set balance = 500 where id = 1";//5.获取执行sql的对象 StatementStatement stmt = conn.createStatement();//6.执行sqlint count = stmt.executeUpdate(sql);//7.处理结果System.out.println(count);//8.释放资源stmt.close();conn.close();

原始jdbc操作的分析

查询数据库必须要有哪些条件:

  • 连接数据库的四个基本信息 driver,url,username,password
  • 必须要有执行的sql语句
  • 必须有结果集对应的实体对象(用于封装数据)

原始jdbc开发存在的问题如下:

  • 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能

  • sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变java代码。

  • 查询操作时,需要手动将结果集中的数据手动封装到实体中。插入操作时,需要手动将实体的数据设置到sql语句的占位符位置

应对上述问题给出的解决方案:

  • 使用数据库连接池初始化连接资源

  • 将sql语句抽取到xml配置文件中

  • 使用反射、内省等底层技术,自动将实体与表进行属性与字段的自动映射

什么是Mybatis

  • mybatis 是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。

  • mybatis通过xml或注解的方式将要执行的各种 statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。

  • 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc 进行了封装,屏蔽了jdbc api 底层访问细节,使我们不用与jdbc api 打交道,就可以完成对数据库的持久化操作。

Mybatis的基本入门

③编写Mybatis核心配置文件:mybatis-config.xml

④编写映射文件UserMapper.xml

⑤编码测试(先理解读懂,后期不用)

导入MyBatis的坐标和其他相关坐标

     <dependencies><!-- 连接数据库必须的依赖 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.32</version></dependency><!-- 方便查看日志,导入该依赖后,控制台可以打印更多日志 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency><!-- 单元测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><!-- lombok --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.10</version></dependency><!-- mybatis依赖,mybatis开发只导入这个依赖即可 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.2</version></dependency></dependencies><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>2.3.2</version><configuration><source>1.8</source><target>1.8</target></configuration></plugin></plugins></build>

编写Mybatis核心配置文件:mybatis-config.xml

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><!--数据源环境--><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><!--数据库的四个基本信息--><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql:///test"/><property name="username" value="root"/><property name="password" value="135246"/></dataSource></environment></environments><!--加载映射文件--><mappers><mapper resource="cs/wy/dao/UserDao.xml"/></mappers></configuration>

4)编写UserMapper映射文件

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- namespace写接口的全类名 --><mapper namespace="cs.wy.dao.UserDao"><!--id写接口中对应的方法名,这里相当于实现了接口中的方法resultType写返回值类型的全类名--><select id="getUser" resultType="cs.wy.domain.User">--    这里写要执行的sql语句select * from user where id=1;</select></mapper>

编写测试代码

    public class MybatisTest {@Testpublic void test01() throws IOException {// 指向mybatis的核心配置文件String resource = "mybatis-config.xml";// 加载核心配置文件到输入流InputStream inputStream = Resources.getResourceAsStream(resource);// 通过核心配置文件创建一个sqlSessionFactory,相当于一个连接工厂SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// jdk7新特性 try with resourcetry (SqlSession session = sqlSessionFactory.openSession()) {// 形式类似于 app.getBean(UserDao.class)UserDao userDao = session.getMapper(UserDao.class);User user = userDao.getUser();System.out.println("user = " + user);}}}

MyBatis的增删改查操作

MyBatis的插入数据操作,

编写UserMapper映射文件

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- namespace写接口的全类名 --><mapper namespace="cs.wy.dao.UserDao"><insert id="saveUser" parameterType="cs.wy.domain.User"><!-- #{}中的值必须是实体类中的属性名称 -->insert into user values (null ,#{username},#{password})</insert></mapper>

插入操作注意问题

  • 在映射文件中使用parameterType属性指定要插入的数据类型,该属性可以省略
  • Sql语句中使用#{实体属性名}方式引用实体中的属性值
  • sqlSession在操作前自动开启了事务。并且插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()
MyBatis的修改数据操作

编写UserMapper映射文件

    <update id="updateUser" ><!-- #{}中的值必须是实体类中的属性名称 -->update user set username=#{username}, password=#{password} where id=#{id}</update>

插入操作注意问题

  • Sql语句中使用#{实体属性名}方式引用实体中的属性值

  • sqlSession在操作前自动开启了事务。并且更新操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

MyBatis的删除数据操作

编写UserMapper映射文件

    <mapper namespace="userMapper"><delete id="delete" parameterType="java.lang.Integer">delete from user where id=#{id}</delete></mapper>

删除操作注意问题

  • 删除语句使用delete标签

  • Sql语句中使用#{任意字符串}方式引用传递的单个参数

  • 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

MyBatis核心配置文件层级关系

MyBatis核心配置文件配置

settings 设置

  1. mapUnderscoreToCamelCase =true | false(default)
  2. mysql默认是大小写不敏感的,所以数据库表名和字段有_命名法的习惯
  3. Java默认是大小敏感的,所以类名、属性名一般会采用驼峰命名法
  4. 命名不一致时,会造成无法正确传值,这个时候可以将上述参数设置为true,会开启自动转换。

typeAliases 类型别名

为单个类起别名

       <typeAliases><typeAlias alias="user" type="cs.wy.domain.User"/></typeAliases>
  1. 批量为某个包下的所有类起别名
       <typeAliases><-- 自动为该包下所有类起别名,并且大小写不敏感--><package name="domain.blog"/></typeAliases>

常用内置数据类型自动别名

别名 映射的类型
_byte byte
_long long
_short short
_int int
_integer int
_double double
_float float
_boolean boolean
string String
byte Byte
long Long
short Short
int Integer
integer Integer
double Double
float Float
boolean Boolean
date Date
decimal BigDecimal
bigdecimal BigDecimal
object Object
map Map
hashmap HashMap
list List
arraylist ArrayList
collection Collection
iterator Iterator

4)environments标签

     <!--数据源环境 指定默认环境名称--><environments default="development"><!--指定当前环境名称--><environment id="development"><!--指定事务管理类型是JDBC--><transactionManager type="JDBC"/><!--指定当前数据源类型时连接池--><dataSource type="POOLED"><!--数据库的四个基本信息--><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql:///test"/><property name="username" value="root"/><property name="password" value="135246"/></dataSource></environment></environments>

其中,事务管理器(transactionManager)类型有两种:

  • JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。

  • MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻止它默认的关闭行为。

其中,数据源(dataSource)类型有三种:

  • UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。

  • POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。

  • JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。

mapper标签:该标签的作用是加载映射的,加载方式有如下几种:

使用相对于类路径的资源引用,例如:

<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>

使用完全限定资源定位符(URL),例如:

<mapper url="file:///var/mappers/AuthorMapper.xml"/>

使用映射器接口实现类的完全限定类名,例如:

<mapper class="org.mybatis.builder.AuthorMapper"/>

将包内的映射器接口实现全部注册为映射器,例如:

<package name="org.mybatis.builder"/>

MyBatis相应API

SqlSession工厂构建器:SqlSessionFactoryBuilder

常用API:SqlSessionFactory build(InputStream inputStream)

通过加载mybatis的核心文件的输入流的形式构建一个SqlSessionFactory对象

    String resource = "org/mybatis/builder/mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = builder.build(inputStream);

其中, Resources 工具类,这个类在 org.apache.ibatis.io 包中。Resources 类可以从类路径下、文件系统或一个 web URL 中加载资源文件。

SqlSession工厂对象:SqlSessionFactory

SqlSessionFactory 有多个个方法创建SqlSession 实例。常用的有如下两个:

SqlSession会话对象

SqlSession 实例在 MyBatis 中是非常强大的一个类。在这里你会看到所有执行语句、提交或回滚事务和获取映射器实例的方法。

执行语句的方法主要有:

    <T> T selectOne(String statement, Object parameter) <E> List<E> selectList(String statement, Object parameter) int insert(String statement, Object parameter) int update(String statement, Object parameter) int delete(String statement, Object parameter)

操作事务的方法主要有:

    void commit()  void rollback()

【SSM框架系列】Mybatis基本介绍相关推荐

  1. JavaWeb学习之路——SSM框架之Mybatis(三)

    数据库配置和相关类创建看上篇:JavaWeb学习之路--SSM框架之Mybatis(二) https://blog.csdn.net/kuishao1314aa/article/details/832 ...

  2. 【重温SSM框架系列】2 - Spring配置数据源连接池(手动创建与配置)

    Spring配置数据源) 数据源(连接池概述) 自定义数据源(手动创建) 1. 导入Druid和mysql数据库驱动依赖包 2. 创建数据源对象并配置基本连接信息 使用JDBC操作数据库,打印user ...

  3. 【重温SSM框架系列】15 - SSM系列博文总结【SSM杀青篇】

    SSM总结 Spring部分 1 - Spring快速入门(配置文件及API详解) 2 - Spring配置数据源连接池(手动创建与配置) 3 - Spring注解开发(注解代替xml文件配置) 4 ...

  4. SSM框架——使用MyBatis Generator自动创建代码

    SSM框架--使用MyBatis Generator自动创建代码 这是通过命令行, 不用ide插件. 若在IDEA中通过插件generator, 还可以参考另一篇: IDEA搭建Spring+Spri ...

  5. 【重温SSM框架系列】1 - Spring快速入门(配置文件及API详解)

    Spring快速入门 Spring是什么 Spring发展历史 Spring的优势 Spring的开发步骤 没有Spring的时候的开发步骤 使用Spring的开发步骤 Spring配置文件(appl ...

  6. SSM框架系列之框架整合教程

    很久之前就想写的教程,因为忙着找实习的原因,没有整理出来,首先SSM框架组合(SpringMVC+Spring+Mybatis)和SSH(Spring4.0+Struts2+Hibernate4.0) ...

  7. 【SSM框架系列】Mybatis映射配置文件与核心配置文件深入

    传统开发方式Dao层实现 编写UserDao接口 public interface UserDao {List<User> findAll() throws IOException;} 编 ...

  8. 【SSM框架系列】SpringMVC基本介绍

    SpringMVC 是web层的框架 SpringMVC 是一种基于 Java 的实现 MVC 设计模型的请求驱动类型的轻量级 Web 框架,属于SpringFrameWork 的后续产品,已经融合在 ...

  9. SSM框架-使用MyBatis Generator自动创建代码

    参考:http://blog.csdn.net/zhshulin/article/details/23912615 SSM搭建的时候用到MyBatis的代码自动生成的功能,由于MyBatis属于一种半 ...

最新文章

  1. 最近做了一个博客 玩玩而已 运城搜搜 www.lenovoyh.com
  2. Javascript学习--------详解window窗口对象
  3. 高校邦python程序设计基础篇_高校邦Python程序设计基础【实境编程】章节答案
  4. dom4j解析xml字符串实例
  5. 资源 | 我拿到了斯坦福、UCL、CMU、NYU的offer,关于博士申请你需要知道的一切...
  6. Java程序卡住问题的解决
  7. 解密朋友圈红包照片功能
  8. mysql导入.sql文件
  9. C语言课程设计|学生成绩管理系统(含完整代码)
  10. Redis常用命令-史上最全最新版本(一)
  11. 华氏度和摄氏度的相互转化
  12. Arthas结合Spring容器 线上排查Tips
  13. Capture One使用的几个小技巧
  14. 测试渲染用什么软件,【2人回答】3DMax2014用的是VRay3.0测试和出图渲染参数怎么设置-3D溜溜网...
  15. AliOS-Things--EMW3060 (9)uart
  16. python中 代表什么,python中是什么意思
  17. 与麻花兄弟诉苦兼讨论欠缺的知识
  18. 六、Docker安装Redis
  19. 字符串分割(split),将字符串按照指定字符进行分割。split(String regex)和split(String regex, int limit)
  20. 使用simulink进行stm32开发1

热门文章

  1. 《Microsoft Sql server 2008 Internal》读书笔记--第八章The Query Optimizer(1)
  2. ICANN:新类别顶级域名2013年才能开放申请
  3. Hibernate学习之一对多关联
  4. textview 滚动显示.txt
  5. 利用Docker构建开发环境
  6. POJ 1001 Exponentiation C++解题报告 JAVA解题报告
  7. [POJ 1003] Hangover C++解题
  8. redis常见关键字
  9. linux下的du命令
  10. Nginx-09:Nginx原理