加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql应用深入理解where 1=1的用处

发布时间:2020-12-12 01:12:07 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用深入理解where 1=1的用处》要点: 本文介绍了Mysql应用深入理解where 1=1的用处,希望对您有用。如果有疑问,可以联系我们。 where 1=1有什么用?在SQL语言中,写这么一句话就跟没写一样. MYSQL学习 select * from table1 where 1=1与select * from

《Mysql应用深入理解where 1=1的用处》要点:
本文介绍了Mysql应用深入理解where 1=1的用处,希望对您有用。如果有疑问,可以联系我们。

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

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

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

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

String sql=select * from table1 where 1=1MYSQL学习

为什么要写多余的1=1?马上就知道了.
MYSQL学习

代码如下:
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是否为空进行检测MYSQL学习

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

拷贝表
create?? table_name?? as?? select?? *?? from?? Source_table?? where?? 1=1; MYSQL学习

复制表结构
create?? table_name?? as?? select?? *?? from?? Source_table?? where?? 1 <> 1; MYSQL学习

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读