php中where1的用法,MySQL_深入理解where 1=1的用处,where 1=1有什么用?在SQL语言中 - phpStudy...

深入理解where 1=1的用处

where 1=1有什么用?在SQL语言中,写这么一句话就跟没写一样。

select * from table1 where 1=1与select * from table1完全没有区别,甚至还有其他许多写法,1<>2,'a'='a','a'<>'b',其目的就只有一个,where 的条件为永真,得到的结果就是未加约束条件的。

在SQL注入时会用到这个,例如select * from table1 where name='lala'给强行加上select * from table1 where name='lala' or 1=1这就又变成了无约束的查询了。

最近发现的妙用在于,在不定数量查询条件情况下,1=1可以很方便的规范语句。例如一个查询可能有name,age,height,weight约束,也可能没有,那该如何处理呢?

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

where 1=1的写法是为了检化程序中对条件的检测

打个比方有三个参数a, b, c

@sql=select * from tb'

这三个参数都可能为空

这时你要构造语句的话,一个个检测再写语句就麻烦

比如

if @a is not null

@sql=@sql + " where a=' + @a

if @b is not null

这里你怎么写?要不要加where 或直接用 and ?,你这里还要对@a是否为空进行检测

用上 where 1=1 之后,就不存在这样的问题, 条件是 and 就直接and ,是or就直接接 or

拷贝表create   table_name   as   select   *   from   Source_table   where   1=1;

复制表结构create   table_name   as   select   *   from   Source_table   where   1 <> 1;相关阅读:

php获取本周开始日期和结束日期的方法

使用mysqladmin检测MySQL运行状态的教程

Android开发技巧之像QQ一样输入文字和表情图像

兼容IE、firefox以及chrome的js获取时间(getFullYear)

php 强制下载文件实现代码

javascript实现十秒钟后注册按钮可点击的方法

Javascript OOP之面向对象

js判断checkbox是否选中个数的方法(超简单)

win10如何还原win7?win10重装win7/win8教程详解

8个必备的PHP功能实例代码

apache php mysql开发环境安装教程

移动端html5图片上传方法【更好的兼容安卓IOS和微信】

如何用cmd连接Mysql数据库

JavaScript中document对象使用详解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值