Mybatis框架 基础
思维导图

@有对应的例子
@1接入数据库 配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd ">
<!--连接数据库需要的配置文件-->
<configuration>
<!-- 使用外部文件传入连接数据库信息 -->
<properties resource ="conf/jdbc_oracle.properties" />
<!-- 简化 在需要写路经的地方可以直接简化掉com.ljk.model这些 -->
<typeAliases>
<package name="com.ljk.model"/>
</typeAliases>
<!-- 连接数据库需要的信息 -->
<environments default="test">
<environment id="test">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.ClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.name}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments> <!--集合 映射文件-->
<mappers>
<!--找到 映射文件的地址-->
<!-- 定义的 映射文件 需要在这里把路经写出来 -->
<mapper resource="com/ljk/mapper/ClasMapper.xml"/>
<mapper resource="com/ljk/mapper/StudentMapper.xml"/>
</mappers>
</configuration>
@2 储存连入数据信息文件
jdbc.name=XXXX
jdbc.password=XXXX
jdbc.ClassName=oracle.jdbc.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
@3 获取SqlSession
/**连接数据库
* @author 墨水瓶
*/
public class Mybatis_DB {
private static SqlSessionFactory sqls;
public static SqlSessionFactory getSqlSessionFactory() {
//写连接数据库 的配置文件
String s = "conf/Mybatis_config.xml";
try {
InputStream in = Resources.getResourceAsStream(s);
sqls = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
return sqls;
}
/**调用这个
* @return 连接数据库
*/
public static SqlSession getSqls() {
if(sqls == null) {
sqls = getSqlSessionFactory();
}
return sqls.openSession();
}
}
@4 级联
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.ljk.mapper.StudentMapper"> <!-- 级联 -->
<!-- 类型为获取到的数据的类型 id与底下对应的select的resultMap一样 -->
<resultMap type="Student" id="resultStudent">
<!-- 一对一查询 返回的是一个clas类 -->>
<association property="_class" column="CLASSID"
select="com.ljk.mapper.ClassMapper.select_class"/>
</resultMap>
<!-- 值为想要连接的resultMap的id的值-->
<select id="select_student" resultMap="resultStudent">
select * from student
</select>
</mapper>
以上为1对1的查询方式
1对多需要用到collection标签
使用级联 时 model 模型类里面的 模型中需要加入对应的属性
例 :
// 在clas 模型类中 需要有一个 Student的集合
// 因为一个班级包含多个学生
private List<Student> student; //在Student 中 有一个Clas 类
// 因为 学生对应着只有一个班级
private Class _class;
@5 映射文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- mapper name属性传入对应接口的限定名 -->
<mapper namespace="com.ljk.mapper.ClasMapper"> <!-- id 对应接口中的方法名 resultType 返回的 类型是一个Clas类-->
<select id="select_clas" resultType="Clas">
<!-- 写sql语句 -->
select * from class c where c.ids = #{ids}
</select> <!-- 传值得时候是条件查询 不传值的时候是全表查询 -->
<select id="select_dong" resultType="clas">
<!-- 动态sql 语句 -->
<!-- 可以根据传入值得不同执行不同的sql语句 -->
select * from class c
<if test="ids != null">
where c.ids = #{ids}
</if>
</select> </mapper>
动态sql语句
1, <if>条件
<if test="key!=null">
拼接sql语句
</if>
2, <choose><when><otherwise>
<choose>
<when test="key=='value'">
拼接sql语句
</when>
<when test="key=='value'">
拼接sql语句
</when>
<otherwise>
拼接sql语句
</otherwise>
</choose>
3, <where>
自动添加where关键字
如果where子句第一句中有 or 或者 and 则删除第一个
4, <trim>
功能与<where>类似, 并且提供了前缀, 后缀的添加, 更加灵活
5, <foreach>
用来遍历传入的集合参数
item(定义集合中每个对象的名字),
collection(集合的对象的名字),
open(定义开始的字符),
close(定义结束的字符),
separator(定义分割的字符)
6, <set>
主要用于update
自动加上set关键字
自动剔除最后一个 ","
7, <sql>
经常用于一些常用或者固定的语句, 在外面定义一个语句, 在各种标签中引入
使用include, 相当于直接写在上面
8, <selectKey>
用于不支持自增长主键的数据库, 尽量避免写这个东西
xml中的 符号
< < 小于号
> > 大于号
& & 和
' ’ 单引号
" " 双引号
符号也可以写到中括号中间使用
<![CDATA[]]>
Mybatis框架 基础的更多相关文章
- MyBatis 框架 基础应用
1.ORM的概念和优势 概念: 对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据 ...
- 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框架基础支持层——反射工具箱之MetaClass(7)
简介:MetaClass是Mybatis对类级别的元信息的封装和处理,通过与属性工具类的结合, 实现了对复杂表达式的解析,实现了获取指定描述信息的功能 public class MetaClass { ...
- Mybatis框架基础支持层——反射工具箱之实体属性Property工具集(6)
本篇主要介绍mybatis反射工具中用到的三个属性工具类:PropertyTokenizer.PropertyNamer.PropertyCopier. PropertyTokenizer: 主要用来 ...
- Mybatis框架基础支持层——反射工具箱之对象工厂ObjectFactory&DefaultObjectFactory(5)
ObjectFactory官方简介:MyBatis每次创建结果集对象的新实例时,它都会使用一个对象工厂(ObjectFactory)实例来完成. 默认的对象工厂需要做的仅仅是实例化目标类,要么通过默认 ...
随机推荐
- RedisPool操作Redis,工具类实例
redis.properties 配置文件内容 redis.pool.maxActive=100redis.pool.maxIdle=20redis.pool.maxWait=3000redis.po ...
- shiro Filter--拦截器
一 shiro自带的filter:下面主要叙述顺序是 NameableFilter->OncePerRequestFilter->AdviceFilter->PathMatching ...
- C#学习之设计模式:工厂模式
最近研究一下设计模式中工厂模式的应用,在此记录如下: 什么是工厂模式? 工厂模式属于设计模式中的创造型设计模式的一种.它的主要作用是协助我们创建对象,为创建对象提供最佳的方式.减少代码中的耦合程度,方 ...
- Ruby学习之对象模型
这两周工作内容较多,平时自己也有点不在状态,学的东西有点少了,趁着现在还有点状态,赶紧复习一下之前学习的Ruby吧. Ruby是我真正开始接触动态语言魅力的第一个语言,之前虽然也用过且一直用perl. ...
- glimmer 3.02安装小记
wget http://www.cbcb.umd.edu/software/glimmer/glimmer302.tar.gz tar xzfglimmer302.tar.gz cd glimmer3 ...
- 基于Vue+node.js的个人博客
前言 作为一个年轻的程序员,而且是作为一个未来的前端工程师,怎么能没有一个属于自己的博客呢,于是乎在暑假咸鱼了一个多月后开始了我的博客的编写. 技术栈 前端 vue.js+scss 因为当时没学vu ...
- Java的静态代码块是否会在类被加载时自动执行?
JAVA静态代码块会在类被加载时自动执行? 一.先看Java静态方法,静态变量 http://www.cnblogs.com/winterfells/p/7906078.html 静态代码块 在类中, ...
- Python可视化库Matplotlib的使用
一.导入数据 import pandas as pd unrate = pd.read_csv('unrate.csv') unrate['DATE'] = pd.to_datetime(unrate ...
- Python 学习笔记大纲
Python Basic 第一章:Python基础の快速认识基本语法 (点击进入博客)我的第一个HelloPython程序.如何实现用户输入.Python的自带电池(模块).变量.格式化.条件判断.循 ...
- apidoc快速生成在线文档,apidoc生成静态文件的生成规则以及原理分析
在老大的指引下,需要将系统的json文件格式转换成apidoc的json格式,也就是json格式的重组,但是这个apidoc的生成格式是不固定的,因为apidoc有自己一套的生成规则,我需要研究一下是 ...