浅淡SQL中where1=1和0=1的作用

where 1=1&where 0=1经常在SQL语句中见到,看见了,过去了,不知道那是什么意思,不知道这条语句的作用,这里笔者为大家一一道来......

创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、网站制作、于洪网络推广、小程序定制开发、于洪网络营销、于洪企业策划、于洪品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供于洪建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com

where 1=1; 这个条件始终为True,在不定数量查询条件情况下,1=1可以很方便的规范语句。

一、不用where  1=1  在多条件查询中的困扰

举个例子,如果您做查询页面,并且,可查询的选项有多个,同时,还让用户自行选择并输入查询关键词,那么,按平时的查询语句的动态构造,代码大体如下:

 
 
 
  1.   string MySqlStr=”select * from table where”;  
  2.  
  3.   if(Age.Text.Lenght>0)  
  4.   {  
  5.     MySqlStr=MySqlStr+“Age=“+“'Age.Text'“;  
  6.   }  
  7.  
  8.   if(Address.Text.Lenght>0)  
  9.   {  
  10.     MySqlStr=MySqlStr+“and Address=“+“'Address.Text'“;  
  11.   }  
  12.  

  ①种假设

  如果上述的两个IF判断语句,均为True,即用户都输入了查询词,那么,最终的MySqlStr动态构造语句变为:

  MySqlStr=”select * from table where Age='18'  and Address='云南省文山州广南县小波吗村'”

  可以看得出来,这是一条完整的正确的SQL查询语句,能够正确的被执行,并根据数据库是否存在记录,返回数据。

  ②种假设

  如果上述的两个IF判断语句不成立,那么,最终的MySqlStr动态构造语句变为:

 
 
 
  1. MySqlStr=”select * from table where“  

  现在,我们来看一下这条语句,由于where关键词后面需要使用条件,但是这条语句根本就不存在条件,所以,该语句就是一条错误的语句,肯定不能被执行,不仅报错,同时还不会查询到任何数据。

  上述的两种假设,代表了现实的应用,说明,语句的构造存在问题,不足以应付灵活多变的查询条件。

二、使用 where  1=1  的好处

  假如我们将上述的语句改为:

 
 
 
  1.   string MySqlStr=”select * from table where  1=1 ”;  
  2.  
  3.  
  4.   if(Age.Text.Lenght>0)  
  5.   {  
  6.     MySqlStr=MySqlStr+“and Age=“+“'Age.Text'“;  
  7.   }  
  8.  
  9.   if(Address.Text.Lenght>0)  
  10.   {  
  11.     MySqlStr=MySqlStr+“and Address=“+“'Address.Text'“;  
  12.   }  
  13.  

  现在,也存在两种假设

  ①种假设

  如果两个IF都成立,那么,语句变为:

  MySqlStr=”select * from table where  1=1 and Age='18'  and Address='云南省文山州广南县小波吗村'”,很明显,该语句是一条正确的语句,能够正确执行,如果数据库有记录,肯定会被查询到。

  ②种假设

  如果两个IF都不成立,那么,语句变为:

  MySqlStr=”select * from table where 1=1”,现在,我们来看这条语句,由于where 1=1 是为True的语句,因此,该条语句语法正确,能够被正确执行,它的作用相当于:MySqlStr=”select * from table”,即返回表中所有数据。

  言下之意就是:如果用户在多条件查询页面中,不选择任何字段、不输入任何关键词,那么,必将返回表中所有数据;如果用户在页面中,选择了部分字段并且输入了部分查询关键词,那么,就按用户设置的条件进行查询。

  说到这里,不知道您是否已明白,其实,where 1=1的应用,不是什么高级的应用,也不是所谓的智能化的构造,仅仅只是为了满足多条件查询页面中不确定的各种因素而采用的一种构造一条正确能运行的动态SQL语句的一种方法。

where 1=0; 这个条件始终为false,结果不会返回任何数据,只有表结构,可用于快速建表

 
 
 
  1. "SELECT * FROM strName WHERE 1 = 0";   
  2.  
  3. //该select语句主要用于读取表的结构而不考虑表中的数据,这样节省了内存,因为可以不用保存结果集。    
  4.  
  5. create table newtable as select * from oldtable where 1=0;  
  6.  
  7.  //创建一个新表,而新表的结构与查询的表的结构是一样的。  

以上便是笔者简要的介绍的关于where 1=1和0=1在SQL中的作用。

原文出处:http://www.cnblogs.com/junyuz/archive/2011/03/10/1979646.html

【编辑推荐】

  1. SQL WHERE子句简介
  2. SQL Where子句的妙用
  3. SQL中where 1=1语句的作用
  4. WHERE语句中设置搜索值的一些建议
  5. Oracle Where子句研究结论

本文名称:浅淡SQL中where1=1和0=1的作用
分享地址:http://www.mswzjz.cn/qtweb/news15/480265.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能