SELECT DISTINCT g.* FROM epms_group g LEFT JOIN epms_member m ON m.saas_group_id = g.saas_group_Id LEFT JOIN epms_visit_country v ON v.saas_group_id = g.saas_group_Id WHERE 1 = 1 <if test="status !=null and status != ''"> and g.status in #{status} </if> order by create_date desc 前端传到后端的状态是多个 比如一,二,三,四, 这里的sql该怎么写
时间: 2024-03-02 15:51:53 浏览: 72
你的 SQL 可以这样写:
```
SELECT DISTINCT g.*
FROM epms_group g
LEFT JOIN epms_member m ON m.saas_group_id = g.saas_group_Id
LEFT JOIN epms_visit_country v ON v.saas_group_id = g.saas_group_Id
WHERE 1 = 1
AND g.status IN (
<foreach collection="status.split(',')" item="item" separator=",">
#{item}
</foreach>
)
ORDER BY create_date DESC
```
这里使用了 MyBatis 的 foreach 标签,将前端传递过来的状态字符串按照逗号分隔为多个参数,然后在 SQL 中进行 IN 查询。
相关问题
SELECT DISTINCT g.* FROM epms_group g LEFT JOIN epms_member m ON m.saas_group_id = g.saas_group_Id LEFT JOIN epms_visit_country v ON v.saas_group_id = g.saas_group_Id WHERE 1 = 1 AND g.status = #{status} ORDER BY create_date DESC 这样就可以直接使用一个参数来进行查询,不需要使用 foreach 标签了写foreach可以只传一个状态吗
是的,可以只传一个状态,使用 foreach 标签也是可以的。例如:
```
SELECT DISTINCT g.*
FROM epms_group g
LEFT JOIN epms_member m ON m.saas_group_id = g.saas_group_Id
LEFT JOIN epms_visit_country v ON v.saas_group_id = g.saas_group_Id
WHERE 1 = 1
AND g.status IN (
<foreach collection="status.split(',')" item="item" separator=",">
#{item}
</foreach>
)
ORDER BY create_date DESC
```
这样写的话,如果只传递一个状态,就可以正常查询,如果传递多个状态,也可以正常查询。
阅读全文