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中设置 ****