• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 深入理解where 1=1的用处

深入理解where 1=1的用处

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了where的音标,where,where是什么意思,where is the love,where are you going等相关知识,希望本文的分享对您有所帮助

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?马上就知道了。

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;

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 深入理解where 1=1的用处

相关文章

  • 2018-12-05Centos7.3安装mysql5.7.18 rpm教程
  • 2018-12-05Oracle下时间转换在几种语言中的实现_Oracle应用_脚本之家
  • 2018-12-05MySQL中使用replace、regexp进行正则表达式替换的用法分析
  • 2018-12-05MySQL中关于日志操作的实例分析
  • 2018-12-05云服务器Centos7.3安装mysql5.7.18 rpm安装步骤
  • 2018-12-05Win7下mysql root账户登录提示:ERROR 1045 (28000)解决方案
  • 2018-12-05有关5.7.18的文章推荐10篇
  • 2017-05-11MySQL中slave监控的延迟情况分析
  • 2018-12-05自动备份Oracle数据库
  • 2017-05-11MySQL中ADDDATE()函数的使用教程

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • SQL Server 2012 SEQUENCE 对象
    • mysql 存储过程 1242-MySQL存储过程ITERATE和LEAVE
    • access的备注字段限制64K
    • 有关锁表问题的文章推荐4篇
    • MySQL数据库系统特权如何查看?
    • 关于mysql innodb count(*)速度慢的解决办法
    • PL/SQL Number数字类型函数
    • MySQL之-CentOS6.5 编译安装MySQL5.6.16的详细代码介绍
    • MySQL优化之—数据类型宽度的简单介绍
    • MySQL审计插件的测试(mcafee和mariadb版本)详情介绍

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有