@Query注解使用详情

@Query注解使用详情

常用属性

value : 取值,要么使用原生SQL,要么使用JPQL

nativeQuery :表示是否采用原生SQL,诸如select * from tableName

取值方式

1、使用:形参名

示例:

单个形参的情况

:参数名

多个形参的情况:

:参数名

2、使用?数值,数值表示形参位置,1表示第一个形参,依次内推

示例:

单个形参的情况:

?数值

多个形参的情况:

?形参序列

特殊情况:数值也可不写,若不写具体的数值,默认是从1开始递增,如下图示例:

特殊情况

3、使用@Param("参数名")+:参数名

通常使用@Param注解都是在多个形参的情况下使用

@Param()

4、获取实体类名称,使用#{#entityName}

使用#{#entityName}

CRUD

使用@Query注解实现删、改、查、增的示例,如下所示:

@Modifying
@Transactional
@Query(value = "delete from User where id = ?1")
void deleteByUserId(Integer id);

?后面的数值1,表示第一个形参的值,以此类推,如果方法有多个形参,数值也会依次递增,特殊情况,数值也可不写,若不写具体的数值,默认是从1开始递增

@Modifying
@Transactional
@Query("update User set email = ?1 where id = ?2")
void updateUser(String email,Integer id);
@Query(value = "select * from tb_user  where  email like concat('%',?2,'%') and username like concat('%',?1,'%') ",nativeQuery = true)
User findByUsernameAndEmail( String username, String email);
@Modifying
@Transactional
@Query(value = "insert into tb_user(email,id_card,username,wage) values (:email,:idCard,:username,:wage)",nativeQuery = true)
void insertUser(String email,String idCard,String username,Double wage);

以上完成了@Query注解的使用详情的介绍,如果觉得小编写的不错的话,给小编点个赞哦,我们下期再见!
关注下方小编的公众号,更多精彩等着你哦

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奔走中的蜗牛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值