度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 644|回复: 2
打印 上一主题 下一主题

[分享] oracle数据库中where 1 = 1的妙用

[复制链接]

348

主题

3572

帖子

9256

积分

论坛元老

Rank: 8Rank: 8

积分
9256
跳转到指定楼层
楼主
发表于 2020-4-4 22:35:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
where 1 = 1是怎where 1 = 1是怎么用的,首先看一段代码,这段代码是我在ebs的总账模块中随便找的一段,以v_开头的都是会给定的变量,不用纠结,大概看看样式就好:么用的,首先看一段代码,这段代码是我在ebs的总账模块中随便找的一段,以v_开头的都是会给定的变量,不用纠结,大概看看样式就好:
  1. SELECT 1
  2.   FROM gl_je_lines gjl
  3. WHERE gjl.ledger_id = v_ledger_id
  4.    AND gjl.reference_5 = v_batch_name
  5. UNION ALL
  6. SELECT 1
  7.   FROM gl_interface gi
  8. WHERE 1 = 1
  9.    AND gi.ledger_id = v_ledger_id
  10.    AND gi.reference25 = v_batch_name
  11.    AND nvl(gi.status,
  12.            'NEW') <> 'PROCESSED';
复制代码

where 1 = 1表示的就是true,就是一个为真的条件,这种用法多用在需要用户输入判断条件的地方,比如说在开发报表的时候,用户会自己输入相应的条件判断。如果,没有where 1= 1,那么只有当where后面的判断语句能够满足的时候才能正常执行;但是,假如后面的判断没有满足,这个时候where后面就没有判断,类型于select * from t_table where,而如果有了where 1 =1 这个条件,那么这个时候就类型于select * from t_table where 1 = 1,这个时候后面就有了一个表示true的条件,执行的时候就不会出现问题。

所以,在做开发的时候,要注意别忘了适当的加上这个条件,如果不知道什么时候该加,那就什么时候都加上吧,这样虽然挺笨,但是也没错。补充一下,至于where 1 = 0的应用,可以用来获取表的结构,如下:

  1. CREATE TABLE t_a
  2. AS
  3. SELECT *
  4.   FROM t_b
  5. WHERE 1 = 0;
复制代码

使用where 1 = 0可以非常方便的获取表结构,去除表中的记录数据。

2014-11-04补充:

在一个SQL语句中,由于from子句是必需的,它总是被第一个评估的子句。如果指定了where子句,那么from子句的评估结果将用于where子句;如果没有指定where子句,那么from子句的评估结果将用于下一个指定的子句,例如,group by子句或having子句。在表达式中的最后一个子句被评估完之后,它的结果将用于select子句。在评估完select子句后,将评估order by子句。


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

328

主题

3738

帖子

8566

积分

作者

Rank: 7Rank: 7Rank: 7

积分
8566
QQ
沙发
发表于 2020-4-5 19:44:09 | 只看该作者
回复

使用道具 举报

328

主题

3738

帖子

8566

积分

作者

Rank: 7Rank: 7Rank: 7

积分
8566
QQ
板凳
发表于 2020-4-5 19:47:57 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-9-29 07:31 , Processed in 0.131044 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表