Mydatis

Mydatis_day2

mapper文件中的另一种取值语法

  1. ${}取值方法的使用
public interface AccountDao{
	Account selectByCardId(@Param("cardId")Integer cardId)
	<select id="selsectByCardId" resultType="com.baizhi.entity.Account">
	select car_id,username,password,balance,mobile from account
	where card_id=${cardId}
	</select>
}

2.#{}于${}两种语法生成SQL语句的方式对比
2.1#{}
#{}以占位符的方式生成SQL语句,可以避免SQL注入的风险
2.2 ${}
${}以字符串拼接的形式生成SQL语句,存在SQL注入的风险

使用Mybatis开发关联关系的查询

  1. 表的设计
    1.1一对一的场景(一对一的场景,表的外键放在哪一方都可以)
    1.2一对多场景(外键存放在多的一方)

  2. Java中的对应实体设计
    2.1一对一:对于关系属性,放置在根据谁找谁的,根据谁的一方。
    2.2一对多:对于关系属性,放置在根据谁找谁的,根据谁的一方。
    PS:关系属性的确立,要根据实际的业务场景进行分析,一般很少有双向关系的场景

  3. 使用Mybatis开发关联关系的查询
    3.1一对mapper实现
    3.2一对多mapper实现

总结

  1. 关联关系Mybati查询的实现
    1.1如果关系属性是一个简单的Java自定义对象类型,使用association标签封装
    1.2如果关系属性是一个list集合,则使用Collection标签封装。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值