sql中的where 1=1有什么用?

1=1 永真       1<>1 永假

1=1常用于拼接动态sql

String sql  =  select * from table1 where 1=1  ;
if(!a.equals("")){
sql=sql+"a='"+a+"'";
}
if(!b.equals("")){
sql=sql+"b'"+b+"'";
}
if(!c.equals("")){
sql=sql+"c='"+c+"'";
}
if(!d.equals("")){
sql=sql+"d='"+d+"'";
}

 

上述例子的四个参数都可能为空, 这时你要构造语句的话,一个个检测再写语句就麻烦,用上 where 1=1 之后,就不存在这样的问题, 条件是 and 就直接and ,是or就直接接 or,如果不写1=1呢,那么在每一个不为空的查询条件面前,都必须判断有没有where字句。否则要在第一个出现的地方加where  。

1<>1 的用处: 用于只取结构不取数据的场合 

拷贝表 

create  table  table_name   as   select   *   from   Source_table   where   1=1;

复制表结构 

create table    table_name   as   select   *   from   Source_table   where   1 <> 1; 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值