oracle中sql优化,这条语句中的where 1=1是什么意思?去掉可以吗?

select*fromt_iprangewhere1=1andENDIPVALUE>=:1andSTARTIPVALUE<=:2不知道开发人员为什么这么写?多余的吧!会影... select * from t_iprange where 1=1 and ENDIPVALUE >= :1 and STARTIPVALUE <= :2
不知道开发人员为什么这么写?多余的吧!
会影响语句的执行性能吗?
展开
 我来答
低调小雄
2014-09-22 · 超过28用户采纳过TA的回答
知道答主
回答量:63
采纳率:0%
帮助的人:45.5万
展开全部
不会影响,良好的开发习惯,只是加了个恒等式。也许你一般看不到影响,下面这种场景你就知道了。
String sql=select * from table1 where 1=1

为什么要写多余的1=1?马上就知道了。

if(!name.equals("")){
sql=sql+"name='"+name+"'";
}
if(!age.equals("")){
sql=sql+"age'"+age+"'";
}
if(!height.equals("")){
sql=sql+"height='"+height+"'";
}
if(!weight.equals("")){
sql=sql+"weight='"+weight+"'";
}

如果不写1=1呢,那么在每一个不为空的查询条件面前,都必须判断有没有where字句,否则要在第一个出现的地方加where
匿名用户
2014-09-22
展开全部
多余的,可以去掉。对性能影响不大。可能1=1后面的查询条件是动态拼的,如果不加1=1就要判断动态加的查询条件是不是第一个,如果是第一个就不需要加AND。这样判断起来比较麻烦,所以直接在前面加1=1,后面再拼查询条件时直接拼AND就可以,不需要判断了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ppphex
推荐于2017-10-13 · TA获得超过325个赞
知道小有建树答主
回答量:266
采纳率:100%
帮助的人:192万
展开全部
写一个1=1是为了后面的条件。这个SQL应该是在程序中拼出来的,程序中首先不能肯定后面的条件是否肯定会有,为了程序简单先加上where 1=1,后面的就可以直接拼接。如果不这样处理就需要在拼接后面的每一个条件时都要判断是不是where子句的第一个件条,以决定是否要在前面加and
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
区块链小趋势
2014-09-22 · TA获得超过2515个赞
知道小有建树答主
回答量:1088
采纳率:0%
帮助的人:702万
展开全部
不会影响性能 这样写只是为了便于后面的条件拼接而已。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式