sql : where 1=1有什么用
来源:互联网 发布:星光大道网络报名方式 编辑:程序博客网 时间:2024/05/16 05:36
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
今天看到:"SELECT * FROM strName WHERE 1 = 0";
不理解为什么有1=0?
查询得出答案:
该select语句主要用于读取表的结构而不考虑表中的数据,这样节省了内存,因为可以不用保存结果集。
另外,这个用在什么地方呢?主要用于创建一个新表,而新表的结构与查询的表的结构是一样的。如下SQL语句:
create table newtable as select * from oldtable where 1=0;
- sql : where 1=1有什么用
- sql 20170915 sql where 1=1有什么意义
- 在SQL语言中,where 1=1有什么用?
- sql 查询条件where 1=1 ,1=2和1=0有什么区别
- SQL语言中where和having有什么区别?
- sql语言中join on和where有什么区别?
- SQL WHERE 1=1
- SQL where 1=1
- 为什么有WHERE 1=1?
- SQL语句 where 1=1 && where 1<>1
- Sql 中的where 1=1 问题
- sql where 1=1 规范代码
- sql中where 1=1
- 1 ZigBee是什么?有什么特点?有什么用?
- SQL语句中where 1=1 对性能的影响,where 与having的区别,where子句的性能
- SQL中where 1=1 和 where 1=0 的妙用
- sql语句中where 1=1和where 1= 0 的使用和区别
- sql中where 1=1 和where 0=1的作用
- Java Swing文本框输入中文弹出输入窗口的解决
- HTML5安全风险详析之二:Web Storage攻击
- 移动设备改变IO,试图改变(数据的)存储和处理(CPU)
- 关于Synchronization
- Java列出数额的清单-DOS小程序
- sql : where 1=1有什么用
- HTML5安全风险详析之一:CORS攻击
- 母亲的唠叨
- 【ERROR】java java.lang.NoClassDefFoundError 的解决办法(全)
- JAVA Web开发之XML基础和DTD约束
- LIB和DLL的区别、建立及使用http://www.cppblog.com/amazon/archive/2009/09/04/95318.html
- 定时器的使用 ---oracle
- 关于触屏智能手机的操作简单说明,安致机型。
- 第7周任务1-求两数正差值