MyBatis 框架 基础应用
1.ORM的概念和优势
概念: 对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据库中。
Mybatis介绍
1.Mybatis是一个支持普通SQL查询、存储过程和高级映射的有限持久层框架。它消除了绝大部分的jdbc代码,简化了手工设置sql参数,对结果级的检索进行了封装。
2.Mybatis 可以使用简单的XML或注解方式来配置映射,将pojo(普通凡人Java对象、实体类对象)映射成数据库中的记录
3.给sql映射文件一个命名空间。程序需要根据命名空间去找到一个具体的映射文件
优势:ORM是持久化的一种解决方案,它提供以下的四个主要功能
(1)基本增删改查的API。 session.save(user)等效于执行一条insert语句
(2)对象或属性查询的API。 session.creatQuery("from User").list()可以查询出表中所有的User对象
(3)规范映射元数据。 ORM解决方案需要规范映射的方式,通常会选择XML存储映射元数据,因为XML便于读取和规范格式
(4)事务控制、延迟加载等优化功能
说明:对象持久化是一个基本概念,ORM是这个概念的一种解决方案,而Mybatis是ORM的一个实现,是一个完整的ORM工具,提供了上述所有的ORM功能。
2.Mybatis 配置文件
1>properties属性
目的:为了方便查阅和维护数据库信息,可以把数据库信息单独卸载一个文件夹中,以后需要使用时再直接引用即可
<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置数据源 -->
<bean id="dataSource"
class="org.apache.commons.dbcp2.BasicDataSource">
<!--数据库驱动 -->
<property name="driverClassName" value="${jdbc.driver}" />
<!--连接数据库的url -->
<property name="url" value="${jdbc.url}" />
<!--连接数据库的用户名 -->
<property name="username" value="${jdbc.username}" />
<!--连接数据库的密码 -->
<property name="password" value="${jdbc.password}" />
</bean>
jdbc.driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
jdbc.url=jdbc:sqlserver://192.168.10.104:1433;databaseName=sa
jdbc.username=sa
jdbc.password=123
2>settings 全局参数配置
<configuration> 标签下有一个<settings> 子表签,可以用来设置Mybatis框架的运行参数,比如设置二级缓存、延迟加载等。修改配置会影响到Mybatis 整体的行为,因此需要谨慎操作
3>为实体类定义别名
1.单个定义别名
<typeAlias type="com.zy.pojo.Customer" alias="customer"/> //不区分大小写
2.批量定义别名
<!-- 给类起别名,在Mapper文件中可以使用别名 -->
<typeAliases>
<package name="com.zy.pojo"/>
</typeAliases>
4>类型处理器
类处理器类型用于Java类型和jdbc类型之间的映射。Mybatis 内置了一些常用的类型处理器,可以将parameterType中传入的参数自动转化为JDBC需要的数据类型
比如说自动给String 类型的参数加上引号
1.内置处理器表
2.自定义类型处理器
为了实现类型转换,定义以下约定,比如
实体类中的性别属性 ture---->男 false----->女
表中的性别属性 1表示男 2表示女
3.使用Mybatis开发的自定义类型处理器,需要实现TypeHandler 接口或继承BaseTypeHandler抽象类,BaseTypeHandler底层实现了TypeHandler接口,并对接口中的方法
做了简单的处 理以方便用户使用,所以用户直接可以继承BaseTypeHandler抽象类
5>动态SQL
Mybatis 提供了<if>、<where>、<foreach>等标签来实现SQL的动态拼接
1.<if>
select * from User where 1=1
<if 条件>
and name like '%${name}%'
<if/>
2.<where> 可使用where标签替代SQL中的where关键字,并且根据实际情况处理<if>开头的and关键字
select * from User
<where>
<if 条件>
and name like '%${name}%'
<if/>
<where/>
3.<foreach>
当输入参数是简单类型或者一般对象类型(除集合和数组外),可以直接指定,但是如果输入参数是集合或者数组类型,就需要使用<foreach>标签来完成参数的处理。
适用途径:数据的批量操作
<select id="queryUser" parameterType="java.util.List" resultType="student">
//1. int[]
//2. Object[]
select * from user <where> <if test="list!=null and list.size()>0">
//1. test="array!=null and array.length>0"
//2.test="array!=null and array.length>0"
<foreach collection="list" open="userid in("close=") item="user" separator>
//1. array
//2. array
#{userid} </foreach> </if> </where> </select>
假设list 集合中有 01,02,03 则完整的sql语句:select * from user where userid in ('01','02','03')
4.sql片段提取
目的:增加代码的复用性
根据id导入
<include refid="sql的id">
MyBatis 框架 基础应用的更多相关文章
- MyBatis框架基础详细开发流程
MyBatis 项目已托管到GitHub,大家可以去GitHub查看下载!并搜索关注微信公众号 码出Offer 领取各种学习资料! 一.框架概述 1.1 什么是框架? 软件的半成品,解决了软件开发过程 ...
- Mybatis框架基础入门(三)--Mapper动态代理方式开发
使用MyBatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper动态代理开发方法. 原始Dao开发方法需要程序员编写Dao接口和Dao实现类,此方式开发Dao,存在以下问题: Dao方 ...
- Mybatis框架基础支持层——日志模块(8)
前言: java开发中常用的日志框架有Log4j,Log4j2,Apache Commons Log,java.util.logging,slf4j等,这些工具对外的接口不尽相同.为了统一这些工具的接 ...
- Mybatis框架基础支持层——反射工具箱之Reflector&ReflectorFactory(3)
说明:Reflector是Mybatis反射工具的基础,每个Reflector对应一个类,在Reflector中封装有该类的元信息, 以及基于类信息的一系列反射应用封装API public class ...
- Mybatis框架基础入门(一)--简介及优势
一.什么是Mybatis 这里借用官网的一句话介绍什么是mybatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC ...
- Mybatis框架 基础
思维导图 @有对应的例子 @1接入数据库 配置文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOC ...
- Mybatis框架基础支持层——反射工具箱之MetaClass(7)
简介:MetaClass是Mybatis对类级别的元信息的封装和处理,通过与属性工具类的结合, 实现了对复杂表达式的解析,实现了获取指定描述信息的功能 public class MetaClass { ...
- Mybatis框架基础支持层——反射工具箱之实体属性Property工具集(6)
本篇主要介绍mybatis反射工具中用到的三个属性工具类:PropertyTokenizer.PropertyNamer.PropertyCopier. PropertyTokenizer: 主要用来 ...
- Mybatis框架基础支持层——反射工具箱之对象工厂ObjectFactory&DefaultObjectFactory(5)
ObjectFactory官方简介:MyBatis每次创建结果集对象的新实例时,它都会使用一个对象工厂(ObjectFactory)实例来完成. 默认的对象工厂需要做的仅仅是实例化目标类,要么通过默认 ...
随机推荐
- 【设计模式】结构型02装饰模式(Decorator Pattern)
装饰模式(Decorator Pattern) 意图:动态地给一个对象添加一些额外的职责.就增加功能来说,装饰器模式相比生成子类更为灵活. 主要解决:一般的,我们为了扩展一个类经常使用继承方式实现,由 ...
- Oracle常用的一些 数据字典 转https://www.cnblogs.com/neozhu/archive/2008/07/22/1248422.html
Oracle常用数据字典表 Oracle常用数据字典表 查看当前用户的缺省表空间 SQL>select username,default_tablespace from user_ ...
- MyBatis从入门到精通(七):MyBatis动态Sql之choose,where,set标签的用法
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用choose, ...
- HDU 2795:Billboard(线段树)
http://acm.hdu.edu.cn/showproblem.php?pid=2795 Billboard Problem Description At the entrance to th ...
- 02(b)多元无约束优化问题-最速下降法
此部分内容接02(a)多元无约束优化问题的内容! 第一类:最速下降法(Steepest descent method) \[f({{\mathbf{x}}_{k}}+\mathbf{\delta }) ...
- 自己实现定制自己的专属java锁,来高效规避不稳定的第三方
java juc 包下面已经提供了很多并发锁工具供我们使用,但在日常开发中,为了各种原因我们总是会用多线程来并发处理一些问题,然而并不是所有的场景都可以使用juc 或者java本身提供的锁来方便的帮助 ...
- c++书籍推荐《C++编码规范》下载
百度云及其他网盘下载地址:点我 编辑推荐 <C++编程规范:101条规则.准则与 实践>:良好的编程规范可以改善软件质量,缩短上市时间,提升团队效率,简化维护工作.在<C++编程规范 ...
- Bzoj 2281 [Sdoi2011]黑白棋 题解
2281: [Sdoi2011]黑白棋 Time Limit: 3 Sec Memory Limit: 512 MBSubmit: 592 Solved: 362[Submit][Status][ ...
- base16,base32,base64 编码方式的通俗讲解
作者:林冠宏 / 指尖下的幽灵 博客:http://www.cnblogs.com/linguanh/ GitHub : https://github.com/af913337456/ 腾讯云专栏: ...
- 基于 Jmeter 的 web 端接口自动化测试平台(转载)
框架 功能点 批量导入har包生成接口用例 接口用例分组树形展示 用例编辑失焦自动保存 用例编写提供快捷调试模块 支持多类型参数,json+文本两种校验 支持同一个项目中接口参数传递 提供即时任务+每 ...