为什么使用where 1=1

本文探讨了在构造动态SQL语句时如何避免语法错误,并通过添加where 1=1来确保即使条件不成立时SQL语句仍能正确执行,同时介绍了如何利用永真和永假条件来获取数据或了解表结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当要构造动态sql语句时

为了防止sql语句结构不当,所以加上where 1=1


如果不加where 1=1

StringBuilder sql=new StringBuilder("select * from  a  where");

if(条件)

sql.append(String.format(“a.value='%s' ”,a_value));

使用上述方法拼接sql,如果条件不满足那剩下的sql为select * from  a  where,会报错


但是按照如下方法,

StringBuilder sql=new StringBuilder("select * from  a  where 1=1");

if(条件)

sql.append(String.format(“and a.value='%s' ”,a_value));

即使条件不满足

where 1=1是永真条件

所以就是select * from a,就会返回表a中所有数据


还有一种永假条件where 1=0或者where 1<>1

有时候可能并不想获得数据,只想知道该表的结构

就会返回所有列,但是没有记录(行)

     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值