Mybatis-02-CRUD及配置解析
CRUD
1.namespace
namespace中的包名要和Dao/Mapper接口的包名一致!
2.select
选择,查询语句; id:对应的namespace中的方法名 resultType:Sql语句执行的返回值 parameterType:参数类型
步骤:
1. 编写接口
2. 编写对应的mapper中的sql语句
3. 测试 增删改需要提交事务
3.insert
## 4.update
5.delete
6.分析错误
- 便签不要匹配错
- resource绑定mapper,需要使用路径
- 程序配置文件必须符合规范
- NullPointerException,没有注册到资源
- 输出的xml文件中存在乱码
- maven资源没有导出的问题
7.万能Map
如果实体类的字段或参数过多,可以考虑使用map。
map传递参数,直接在sql中取出key即可; 而对象传递参数,直接在sql中取出属性即可。
多个参数用Map,或者注解!
8.思考题
模糊查询怎么写? 1.java代码执行的时候,参数中包含通配符‘%’ 2.在sql拼接中使用通配符
-------------------------正片开始
配置解析(重要)
1.核心配置文件
mybatis-config.xml configuration(配置): properties(属性) settings(设置) typeAliases(类型别名) typeHandlers(类型处理器) objectFactory(对象工厂) plugins(插件) environments(环境配置) environment(环境变量) transactionManager(事务管理器) dataSource(数据源) databaseIdProvider(数据库厂商标识) mappers(映射器)
2.环境配置(environments)
Mybatis可以配置适应多种环境,不过每个sqlSessionFactory实例只能选择一种环境。 其中,Mybatis默认的事务管理器是JDBC,默认的连接池是POOLED。
3.属性(properties)
我们可以通过propertis属性来实现引用配置文件 编写一个配置文件 db.properties 在核心配置文件中映入 可以直接引用外部文件,也可以在其中增加一些属性配置,外部文件优先级大。
4.类型别名(typeAliases)
只和xml配置相关,用于减少完全限定名的冗余
typeAlias / package=在类名上加注解 @Alias(别名)
5.设置(setting)
6.其他配置
typeHandlers(类型处理器) objectFactory(对象工厂) plugins(插件)
7.映射器(mappers)
MapperRegistry:注册绑定我们的Mapper文件; 1.resource绑定mapper 2.class 注意点:接口和mapper配置文件同名且在一个包下 3.package: 注意点:扫描包下的接口和mapper配置文件必须同名且在一个包下。
8.生命周期和作用域(Scope)
错误的使用导致并发问题。 SqlSessionFactoryBuild: 一旦创造SqlSessionFactory,就不再需要了。 局部变量 SqlSessionFactory: 一旦被创建,运行期间就一直存在,没必要丢弃或重建。 最佳作用域:应用作用域。 SqlSession: 连接到连接池的一个请求,需要开启和关闭。 不是线程安全的,最佳作用域是方法作用域。
解决属性名和字段名不一致的问题
引出结果集映射:resultMap
resultMap元素是Mybatis中最强大的元素
Mybatis-02-CRUD及配置解析的更多相关文章
- MyBatis源码 核心配置解析 properties元素
XMLConfigBuilder的parseConfiguration(XNode)方法,用于解析配置文件 XMLConfigBuilder的propertiesElement(XNode)方法,用于 ...
- MyBatis(3)——配置解析
MyBatis中文参考指南:MyBatis用户指南 //------------核心配置文件说明------------// //*在注释中进行说明 <configuration> < ...
- MyBatis学习02(配置解析)
配置解析 核心配置文件 mybatis-config.xml 系统核心配置文件 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息. 能配置的内容如下: configur ...
- Mybatis源码解析,一步一步从浅入深(三):实例化xml配置解析器(XMLConfigBuilder)
在上一篇文章:Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码 ,中我们看到 代码:XMLConfigBuilder parser = new XMLConfigBuilder(read ...
- Mybatis:配置解析
配置解析 mybatis-config.xml(Mybatis核心配置文件)深深影响了Mybatis行为的设置和属性信息. 能配置的的内容 当然,并不是所有都是我们经常使用到的,下面选择经常使用的配 ...
- MyBatis:配置解析
配置解析 核心配置文件 mybatis-config.xml 系统核心配置文件 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息. 能配置的内容如下: configur ...
- 深入Mybatis源码——配置解析
@ 目录 前言 正文 配置解析 1. cacheRefElement/cacheElement 2. resultMapElements 3. sqlElement 4. buildStatement ...
- 4、MyBatis教程之配置解析
5.配置解析 核心配置文件 mybatis-config.xml 系统核心配置文件 MyBatis 的配置文件会深深影响 MyBatis 行为的设置和属性信息. 能配置的内容如下: configura ...
- Mybatis配置解析(核心配置文件)
4.配置解析 4.1.核心配置文件 Mybatis的配置文件包含了会深深影响mybatis行为的设置和属性信息 mybatis-config.xml properties(属性)重点 settings ...
- 后端框架的学习----mybatis框架(3、配置解析)
3.配置解析 1.核心配置文件 2.环境配置(environment) 3.属性(properties) 可以通过properties属性来实现引用配置文件 这些属性可以在外部进行配置,并可以进行动态 ...
随机推荐
- nginx的基础学习+实战
文章目录 一.前言 二.反向代理 三.负载均衡 四.动静分离 参考视频:尚硅谷Nginx教程(2019发布) 参考链接:Windows下Nginx负载均衡实现 一.前言 Nginx (engine x ...
- PHP常见的十个安全问题
相对于其他几种语言来说, PHP 在 web 建站方面有更大的优势,即使是新手,也能很容易搭建一个网站出来.但这种优势也容易带来一些负面影响,因为很多的 PHP 教程没有涉及到安全方面的知识. 此帖子 ...
- 题解 洛谷 P3521 【[POI2011]ROT-Tree Rotations】
给定一棵二叉树,叶子节点有权值,可以进行若干次交换一个节点的左右儿子的操作,使前序遍历叶子的逆序对最少. 考虑一个节点下子树逆序对的产生: ① 只在左子树中产生. ② 只在右子树中产生. ③ 在左子树 ...
- redis基本操作介绍
一.字符串 单个设置:set key value,如果key不存在则设置键值对,如果存在则修改 批量设置:mset key1 value1 [key2 value2] 单个获取:get key,如果k ...
- Elasticsearch必知必会的干货知识二:ES索引操作技巧
该系列上一篇文章<Elasticsearch必知必会的干货知识一:ES索引文档的CRUD> 讲了如何进行index的增删改查,本篇则侧重讲解说明如何对index进行创建.更改.迁移.查询配 ...
- Excel绘制经典图表
1.柱形图 2.条形图 3.饼图---复合饼图 4.圆环图 5.组合图 设置不同的纵轴 6.漏斗图 其中:合计呈逐渐下降的趋势,可以用漏斗图进行展示! 绘制漏斗图首先需要构建辅助列,在插入图形的时候选 ...
- PHP array_intersect_key() 函数
实例 比较两个数组的键名,并返回交集: <?php$a1=array("a"=>"red","b"=>"gree ...
- PHP strptime() 函数
------------恢复内容开始------------ 实例 解析由 strftime() 生成的时间/日期: <?php$format="%d/%m/%Y %H:%M:%S&q ...
- c++ explict
explicit 用于一个参数的构造函数:防止隐式转换. 什么意思呢? myClass(int x); 这是个构造函数 我们可以使用 myClass a(4); 或 myClass a=4;来调用它 ...
- C++关于智能指针
有四种: auto_ptr<class T> unique_ptr<class T> shared_ptr<class T> weak_ptr<class T ...