mybatis基础笔记二

简介: mybatis基础笔记二

1.4  mybatis的约定以及基于动态代理的CRUD****

1.4.1基础方式的增删改查CRUD****

1. mybatis约定:****

输入参数parameterType 和 输出参数resultType ,在形式上都只能有一个

如果输入参数 :是简单类型(8个基本类型+String) 是可以使用任何占位符,#{xxxx}

如果是对象类型,则必须是对象的属性 #{属性名}

输出参数:  如果返回值类型是一个 对象(如Student),则无论返回一个、还是多个,

再resultType都写成org.lanqiao.entity.Student

即 resultType="org.lanqiao.entity.Student"

2. 注意事项:****

a如果使用的 事务方式为 jdbc,则需要 手工commit提交,即session.commit();

b所有的标签  等 ,都必须有sql语句,但是sql参数值可选 select* from student  where stuno = #{xx} sql有参数:session.insert(statement, 参数值 ); sql没参数:session.insert(statement); 1.4.2 mapper动态代理方式的crud (MyBatis接口开发):**** 1.原则:约定优于配置**** 2.硬编码方式****    abc.java Configuration conf = new Configuration(); con.setName("myProject") ; 3.配置方式:**** abc.xml    myProject 约定:默认值就是myProject**** 1.4.3 MyBatis接口开发实现步骤*** 1.4.3.1基础环境:**** mybatis.jar/ojdbc.jar、conf.xml、mapper.xml**** 1.4.3.2 约定**** ****约定的目标: 省略掉statement,即根据约定 直接可以定位出SQL语句 1 接口,接口中的方法必须遵循以下约定:****  *1.方法名和mapper.xml文件中标签的id值相同  * 2.方法的 输入参数 和mapper.xml文件中标签的 parameterType类型一致 (如果mapper.xml的标签中没有 parameterType,则说明方法没有输入参数) 3.方法的返回值  和mapper.xml文件中标签的 resultType类型一致 (无论查询结果是一个 还是多个(student、List),在mapper.xml标签中的resultType中只写 一个(Student);如果没有resultType,则说明方法的返回值为void)****   2. 除了以上约定,要实现 接口中的方法  和  Mapper.xml中SQL标签一一对应,还需要以下1点:**** namespace的值 ,就是  接口的全类名( 接口 - mapper.xml 一一对应) 1.4.3.3 匹配的过程:(约定的过程) 1.根据 接口名 找到 mapper.xml文件(根据的是namespace=接口全类名) 2.根据 接口的方法名 找到 mapper.xml文件中的SQL标签 (方法名=SQL标签Id值) 以上2点可以保证: 当我们调用接口中的方法时,**** 程序能自动定位到 某一个Mapper.xml文件中的sqL标签**** 习惯:SQL映射文件(mapper.xml) 和 接口放在同一个包中 (注意修改conf.xml中加载mapper.xml文件的路径)   以上,可以通过接口的方法->SQL语句 执行: StudentMapper studentMapper = session.getMapper(StudentMapper.class) ; studentMapper.方法(); 通过session对象获取接口(session.getMapper(接口.class);),再调用该接口中的方法,程序会自动执行该方法对应的SQL。 **** 1.4.3.4 优化**** 1.可以将配置信息 单独放入 db.properties文件中,然后再动态引入  db.properties:文件 k=v   <properties  resource="db.properties"/> 引入之后,使用${key}****     1.4.4 MyBatis全局参数(尽量不要动)**** 在conf.xml中设置 ****

相关文章
|
6月前
|
Java 数据库连接 数据库
Mybatis逆向工程笔记小结
Mybatis逆向工程笔记小结
|
2月前
|
SQL Java 数据库连接
【Java笔记+踩坑】MyBatisPlus基础
MyBatisPlus简介、标准数据层开发CRUD、业务层继承IService、ServiceImpl、条件查询、LambdaQueryWrapper、id生成策略、逻辑删除、乐观锁@Version、代码生成器、ActiveRecord
【Java笔记+踩坑】MyBatisPlus基础
|
2月前
|
Java 数据库连接 数据格式
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
IOC/DI配置管理DruidDataSource和properties、核心容器的创建、获取bean的方式、spring注解开发、注解开发管理第三方bean、Spring整合Mybatis和Junit
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
|
6月前
|
SQL Java 关系型数据库
MyBatis-Plus全套笔记三
MyBatis-Plus全套笔记三
|
6月前
|
SQL Java 数据库连接
MyBatis-Plus全套笔记二
MyBatis-Plus全套笔记二
|
6月前
|
Java 关系型数据库 数据库连接
MyBatis-Plus全套笔记一
MyBatis-Plus全套笔记一
131 1
|
SQL Java 数据库连接
[推荐] MyBatis框架初学笔记-为之后拾遗
[推荐] MyBatis框架初学笔记-为之后拾遗
57 0
|
SQL 存储 缓存
MyBatis 学习心得笔记
MyBatis 学习心得笔记
95 0