5.解决列名与属性名不一致的情况

1.在SQL查询语句中使用别名来适配

1  <select id="getOrder" parameterType="int" resultType="com.zhiyou100.wc.bean.Orders">
2           select order_id id,order_no no,order_price price from Orders where order_id=#{id}   
3     </select> 

2. 自定义ResultMap

 1 <!-- resultMap:引用resultMap标签
 2             resultMap和resultType只能出现一个
 3      -->
 4     <select id="getOrder" resultMap="myMap">
 5         select * from orders where order_id=#{id}
 6     </select>
 7     <!-- resultMap:写属性与字段的对应关系
 8             type:表示哪个实体类与表的对应关系
 9      -->
10     <resultMap type="com.zhiyou100.wc.bean.Orders" id="myMap">
11         <!-- id:标签标实表中的主键与实体类的值属性对应关系 -->
12         <id property="id" column="order_id"/>
13         <result property="no" column="order_no"/>
14         <result property="price" column="order_price"/>
15     </resultMap>

 

转载于:https://www.cnblogs.com/banzhuanlaowang/p/11455279.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EF Core框架,数据库表的列名和实体属性一致是一个常见的情况。这种情况可能出现在数据库设计,为了符合统一的命规范,数据库表的列名可能使用下划线分隔,而实体属性可能使用驼峰命法。 为了解决这个问题,EF Core提供了一些特性和约定,可以映射数据库列名和实体属性之间的关系。其最常用的特性是`Column`和`Table`特性。 `Column`特性用于将实体属性映射到数据库表的列名。例如,如果数据库表列名是`first_name`,而实体属性是`FirstName`,可以在实体属性上使用`[Column("first_name")]`特性来进行映射。 `Table`特性用于将实体映射到数据库表的称。如果数据库表的称与实体称不一致,可以在实体上使用`[Table("table_name")]`特性来指定对应的表。 除了特性,EF Core还支持一些约定,根据命规则自动进行映射。例如,默认情况下,EF Core会将实体属性映射到数据库表的列名,只需保证它们的一致即可。如果数据库列名是多个单词的组合,使用下划线分隔,EF Core会将其转换为驼峰命法。 总结来说,EF Core提供了特性和约定来处理数据库列名和实体列名一致情况。通过使用`Column`和`Table`特性、遵循命约定,可以实现灵活的映射,确保数据在实体和数据库表之间的正确转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值