有两张表,分别为A、B,求得一个字段的值先在表A中寻找,如果A表中存在数据,则输出A表的值;如果A表中不存在,则在B表中寻找,若B表中有相应记录,则输出B表的值;如果B表中也不存在,则输出"no records”字符串。

with
sql1 as (select to_char(a) s_name from test_tempa),
sql2 as (select to_char(b) s_name from test_tempb where not exists (select s_name from sql1 where rownum=1))
select * from sql1
union all
select * from sql2
union all
select 'no records' from dual  where not exists (select s_name from sql1 where rownum=1)  and not exists (select s_name from sql2 where rownum=1);  

再举个简单的例子

with a as (select * from test)

select * from a;

其实就是把一大堆重复用到的SQL语句放在with as 里面,取一个别名,后面的查询就可以用它

这样对于大批量的SQL语句起到一个优化的作用,而且清楚明了

with/as 用法相关推荐

  1. c语言中external,static关键字用法

    static用法: 在C中,static主要定义全局静态变量.定义局部静态变量.定义静态函数. 1.定义全局静态变量:在全局变量前面加上关键字static,该全局变量变成了全局静态变量.全局静态变量有 ...

  2. Pandas_transform的用法

    先来看一个实例问题. 如下销售数据中展现了三笔订单,每笔订单买了多种商品,求每种商品销售额占该笔订单总金额的比例.例如第一条数据的最终结果为:235.83 / (235.83+232.32+107.9 ...

  3. Python中yield和yield from的用法

    yield 后面接的是 future 对象 调用方 委托生成器 yield from 直接给出循环后的结果 yield from 委托者和子生成器直接通信 yield from 直接处理stopIte ...

  4. pytorch学习 中 torch.squeeze() 和torch.unsqueeze()的用法

    squeeze的用法主要就是对数据的维度进行压缩或者解压. 先看torch.squeeze() 这个函数主要对数据的维度进行压缩,去掉维数为1的的维度,比如是一行或者一列这种,一个一行三列(1,3)的 ...

  5. python yield 和 yield from用法总结

    #例1. 简单输出斐波那契數列前 N 个数 #缺点:该函数可复用性较差,因为 fab 函数返回 None,其他函数无法获得该函数生成的数列 #要提高 fab 函数的可复用性,最好不要直接打印出数列,而 ...

  6. tf.nn.embedding_lookup()的用法

    函数: tf.nn.embedding_lookup( params, ids, partition_strategy='mod', name=None, validate_indices=True, ...

  7. OpenMP用法大全

    OpenMP基本概念 OpenMP是一种用于共享内存并行系统的多线程程序设计方案,支持的编程语言包括C.C++和Fortran.OpenMP提供了对并行算法的高层抽象描述,特别适合在多核CPU机器上的 ...

  8. Dorado用法与示例

    Dorado用法与示例 dorado用后总结 一.dorado概念 dorado的产品全名是"dorado展现中间件".从产品形态上dorado由两部分组成,第一部分是一个具有AJ ...

  9. TensorFlow用法

    TensorFlow用法 什么是TensorFlow TensorFlow是一个开源软件库,用于使用数据流图进行数值计算.图中的节点表示数学运算,而图的边缘表示流动的多维数据数组(张量).这种灵活的体 ...

  10. TensorFlow Keras API用法

    TensorFlow Keras API用法 Keras 是与 TensorFlow 一起使用的更高级别的作为后端的 API.添加层就像添加一行代码一样简单.在模型架构之后,使用一行代码,可以编译和拟 ...

最新文章

  1. 查看显卡显存_强力散热别浪费 显卡超频这样搞
  2. Django 框架 数据库操作
  3. 如何限制创建子网站时只能使用指定的模板
  4. 吐血整理!内部包含3980大数据、机器学习、推荐系统实战课程,仅分享一次
  5. 穿透还原12.1新变种病毒样本
  6. [leetcode-117]填充每个节点的下一个右侧节点指针 II
  7. JQuery中serialize()、serializeArray()和param()方法示例介绍
  8. android ProgressBar 进度条demo
  9. 第P题 扔盘子(双重循环就行) 详解=====有一口井,井的高度为N,每隔1个单位它的宽度有变化。现在从井口往下面扔圆盘,如果圆盘的宽度大于井在某个高度的宽度
  10. WebView之加载网页时增加进度提示
  11. 中国计算机管理软件学院,中国管理软件学院官方网站
  12. 加快二代支付系统建设改进央行支付清算服务
  13. 设计思维Design Thinking
  14. Response.AddHeader使用实例
  15. ios:苹果手机直接安装ipa文件
  16. 浙江大学求是科学班计算机,浙江大学“汉语言文学(求是科学班)”2020年招生简章...
  17. 系统之家启动维护光盘v3.0[小盘·贺岁篇]
  18. 因果推断(Causal Inference)概要
  19. 自动解题批改与自适应学习 AI在教育行业的应用实践
  20. 我看了《2018 微信数据报告》,你呢?

热门文章

  1. WordPress博客自媒体主题:Autumn自定义主题配色
  2. 《精益数据分析》:网易创始人丁磊力荐
  3. H264BSAnalyzer 使用方法
  4. 访问网络共享找不到网络名的解决方案
  5. win7 去掉快捷方式小箭头
  6. HLS directive
  7. AWS Lambda重大更新,跨越编程语言差异之门?
  8. node-webkit:开发桌面+WEB混合型应用的神器
  9. 修改页面变成灰色代码修改方法
  10. cpu功耗排行_AMD、Intel CPU处理器性能、功耗及性价比排行(更新中)