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注入时会用到这个,例如select * from table1 where name=’lala’给强行加上select * from table1 where name=’lala’ or 1=1这就又变成了无约束的查询了。 最近发现的妙用在于,在不定数量查询
### SQL语法的各种妙用 #### 一、动态执行SQL语句 在SQL中,我们可以使用动态执行SQL语句的方式来进行一些灵活的操作。这种方式通常适用于那些需要在运行时确定查询细节的情况。 **示例代码:** ```sql DECLARE ...
### SQL语句妙用指导——SQL的便捷及巧妙用法详解 #### 一、动态SQL语句基础 在SQL编程中,动态SQL是指在运行时根据条件构建的SQL语句。这种方式非常灵活,尤其适用于需要根据不同的输入动态生成查询的情况。 **1...
### SQL语句妙用指导 #### 一、动态SQL语句基本语法 在SQL Server中,动态SQL是一种非常有用的技巧,允许用户构建和执行在运行时确定的SQL语句。这种方式特别适合于需要构建复杂查询或者需要根据输入参数变化的...
本篇文章将深入探讨SQL语句的妙用,以及各种SQL语句的详细用法和讲解。 一、SQL基础 1. 数据库创建:使用`CREATE DATABASE`语句创建新的数据库,例如`CREATE DATABASE MyDatabase;`。 2. 表的创建:在已有的...
在文档"sql语句妙用.doc"中,主要讲述了SQL语句的一些高级用法,特别是动态SQL和与Identity列相关的操作。 首先,动态SQL是SQL中一个非常重要的特性,允许在运行时构建和执行SQL命令。在例子中,`EXEC`和`sp_...
本篇文章将详细讲解SQL语句的妙用,特别是动态SQL的应用,以及在SQL Server中处理Identity列的方法。 首先,我们来看动态SQL的基本语法。动态SQL允许我们在运行时构建和执行SQL语句,这对于处理不确定的列名、表名...
SQL(Structured Query Language)是用于管理和处理关系数据库的标准语言,其妙用在于能够灵活地对数据进行查询、更新、插入和删除等操作。本篇文档主要涵盖了SQL语句的详细用法,特别是针对DB2、Oracle和SQL Server...
SQL语句是数据库管理的核心工具,...总结来说,SQL语句的妙用和详细用法涵盖了动态SQL的构造、结果输出、`IDENTITY`列的管理和通用查询语句的构建。理解并熟练运用这些技巧,将有助于更高效地进行数据库操作和管理。
本资料“sql语句妙用-各种sql语句的详细用法与讲解”旨在深入浅出地介绍SQL的各种用法,帮助用户提升在数据库管理中的技能。 一、SQL基础 SQL的基础包括数据定义(DDL,Data Definition Language),数据操作(DML...
本篇文章将深入探讨SQL语句的妙用和详细用法。 首先,我们要了解SQL语句的基础概念。SQL主要包括四大基本操作:SELECT(查询)、INSERT(插入)、UPDATE(更新)和DELETE(删除)。除此之外,还有DDL(Data ...
1. **执行普通SQL语句**: - 使用`EXEC`或`sp_executesql`存储过程来执行字符串形式的SQL语句。例如,`EXEC('select * from tableName')`会返回`tableName`表的所有行。 2. **变量与动态SQL**: - 当字段名、表名...
本篇文章主要探讨了SQL语句的一些妙用,包括动态SQL、输出参数以及对Identity列的操作,这些都是提高开发效率和灵活性的重要技巧。 首先,动态SQL是SQL中的一个强大特性,它允许我们在运行时构建和执行SQL语句。...
通过理解并熟练运用这些SQL语句的妙用,开发者可以更高效地处理各种复杂的数据库操作,从而提升数据库管理与应用开发的水平。记住,动态SQL和对Identity列的管理是SQL Server中不可或缺的一部分,它们在实际工作中...
以上只是SQL语句妙用的一部分,实际的SQL语言还包括更复杂的查询构造,如`JOIN`操作、子查询、聚合函数、分组和排序等。熟练掌握SQL能极大地提高数据操作的效率和灵活性,对于软件开发者来说是一项必不可少的技能。