1 在使用mybatis框架时,使用Resouces.getResourceAsStream()方法时出错:
提示该类没有如下方法
解决方法:使用Resources.class.getResourcesAsStream()才可
原因:
2 使用mybatis框架配置文件存放的位置
3 mybatis配置文件中个标签放置有先后顺序
- 如果需要引入db.properties文件时,这个标签应放在最上面
- 其次<typealease 表签不能放在<elements之后,否则会报错
4 ResultMap中的id 和result的区别
<resultMap type="com.zwwhnly.mybatisaction.model.Classes" id="ClassResultMap4">
<id property="id" column="c_id"/>
<result property="name" column="c_name"/>
<association
property="teacher" column="teacher_id" javaType="com.zwwhnly.mybatisaction.model.Teacher" select="getTeacher2">
</association>
<collection property="students" ofType="com.zwwhnly.mybatisaction.model.Student" column="c_id" select="getStudent"></collection>
</resultMap>
在自定义的resultMap中第一列通常是主键id,那么id 和result有什么区别呢?
id和result都是映射单列值到一个属性或字段的简单数据类型。
唯一不同是。id是作为唯一标识的,当和其他对象实例对比的时候,这个id很有用,尤其是应用到缓存和内嵌的结果映射。
property: 映射数据库列的字段或属性,如果JavaBean的属性与给定的名称匹配,就会使用匹配的名字,否则MyBatis将搜索给定名称的字段,两种情况下你都可以使用逗点的属性形式,比如,你可以映射到“”username:,也可以映射到“address.street.number”
column:数据库的列名或者列标签别名,与传递个resultSet.getString(columnName)的参数名称相同。
javaType:完整java类名或者别名,如果映射到一个JavaBean,那么MyBatis通常会自行监测到。然而如果映射到一个HashMap,那应该明确指定javaType来确保所需行为。
jdbcType;支持的jdbc类型,这个属性只在insert,update,delete的时候针对允许空的列有用,JDBC需要这项,但Mybatis不需要,如果直接编写JDBC代码,在允许为空值的情况下需要指定这个类型。