1.Spring 补充
1).数据的结构: Map 理解为容器
2).数据内容: KEY-VALUE
-KEY:一般都是类名的首字母小写 helloController
-Value: 一般存储的是经过反射等机制实例化的对象
Map<helloController,controller对象>
3).单例: 容器中只保存一个对象, spring容器管理对象的生命周期 和容器几乎同生共死
默认:单例对象
多例: 如果用户需要使用,则新创建一个对象交给用户使用,由用户管理对象的生命周期.
2. MP介绍
MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
重点说明: MP适用于单表操作 如果遇到多表关联,则手写Sql效率更高。
3. MP的工作原理
1).通过注解 实现对象与表一一映射.
2).通过属性注解 实现对象的属性与表中的字段一一映射.
3).将公共的方法进行抽取,抽取到BaseMapper接口中
4).将用户操作的方法对象,转化为数据库能够识别的Sql语句.
demo1: userMapper.insert(user对象)
Sql1: insert into 表名(字段名…) value (属性值…)
拼接过程:
insert into 表名(字段名…) value (属性值…)
1). 通过userMapper 查找父级接口BaseMapper
2). 根据BaseMapper 查找泛型对象 User对象.
3).根据user对象 查找指定的注解 @TableName,获取表名
4).根据user对象的属性,动态获取表中的字段.@TableField
5).在获取字段的同时,获取属性的值,最后进行sql拼接
6).MP将拼接好的Sql交给Mybatis框架处理执行.
insert into demo_user(id,name…) value (value1,value2…)