MyBatis执行sql语句时,实体类名和数据库列名不一致如何解决?以及关于sql参数占位符的使用和特殊字符的处理!!!

1、MyBatis执行sql语句时,实体类名和数据库列名不一致时:

方法1(起别名):

 *起别名:对不一样的列名起别名,让别名跟实体类的属性名一样 缺点:每次查询都要定义一次别名
       缺点:每一次查询都要定义一次别名
       <select id="selectAll" resultType="brand">
       select id,brand_name as brandName,company_name as companyName,ordered,description,status from tb_brand;
       </select>

方法2(sql片段插入):

   *sql片段
       缺点:不灵活
       例子:
       <sql id="brand_column">
       id,brand_name as brandName,company_name as companyName,ordered,description,status
       </sql>
       <select id="selectAll" resultType="brand">
       select <include refid="brand_column" /> from tb_brand;
       </select>

方法3(resultMap标签):

       *resultMap:
       定义resultMap标签, 
        resultMap中有两个属性
       (1)id:完成主键字段的映射
       (2)result:完成一般字段的映射 这两个属性都含有column:表的列名,property:实体类的属性名
      
       <resultMap id="userResultMap" type="user"> id:唯一标识 type:映射的类型,支持别名
       <result column="brand_name" property="brandName"></result> 
       <result column="company_name" property="companyName"></result>
       </resultMap>

       在<select>标签中,使用resultMap属性替换resultType属性
       <select id="selectAll" resultType="userResultMap">
        select * from user;
        </select>

2、关于sql参数占位符的使用和特殊字符的处理

在SQL语句中,会用到一些参数以及标准符号的使用,如下面sql语句:

    <select id="selectById" resultType="user">
        select * from user where uid = #{uid};
    </select>

#{uid} 就是参数占位符,= 就是特殊符号。

特殊字符处理:

1.转义字符:
<    符号相当于:  &lt;
2.CDATA区:
<    符号相当于:  <![CDATA[
                <
                ]]>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值