Java——Mybatis常见问题(id,result、配置文件标签顺序、配置文件存放目录)

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代码,在允许为空值的情况下需要指定这个类型。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值