Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >按顺序从多个表查询数据

按顺序从多个表查询数据
EN

Stack Overflow用户
提问于 2016-05-20 21:29:04
回答 3查看 297关注 0票数 0

项目价格将从多个价格表中检索。每个项目的价格可能不是在所有的桌子上。查询序列是基于表优先级的。查询将在价格可用时停止。

例如:价格表有T1、T2和T3,表查询顺序和优先级是T1、T2和T3。

T1表记录

代码语言:javascript
运行
AI代码解释
复制
Item, Price
I1, $11
I3, $13
I4, $14

T2表记录

代码语言:javascript
运行
AI代码解释
复制
Item, Price
I2, $21
I3, $23
I5, $25

T3表记录

代码语言:javascript
运行
AI代码解释
复制
Item, Price
I1, $31
I2, $32
I6, $33

结果:

代码语言:javascript
运行
AI代码解释
复制
Item I1 is $11, I3 is $13, 
 and I4 is $14.

它将从T1检索,这是第一个优先级表。因为价格是在T1中提供的,所以它不会搜索T2和T3。

项目I2和I5将来自表T2。

它们在第一个优先级表T1中不可用,查询移到第二个优先级表T2。

项目I6将来自T3。

因为I6不在T1和T2中。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-05-20 22:09:32

代码语言:javascript
运行
AI代码解释
复制
; with item as
(
    select item from T1
    union
    select item from T2
    union
    select item from T3
)
select    item  = i.item,
          value = coalesce(v1.value, v2.value, v3.value)
from      item i
left join T1 v1  on i.item  = v1.item
left join T2 v2  on i.item  = v2.item
left join T3 v3  on i.item  = v3.item
票数 1
EN

Stack Overflow用户

发布于 2016-05-20 22:02:15

也许是这样的?

代码语言:javascript
运行
AI代码解释
复制
create table #item1(
    item int,
    value int
)

insert into #item1 values
(1,1),
(2,2)

create table #item2(
    item int,
    value int
)

insert into #item2 values
(1,10),
(2,20),
(3,30)

create table #item3(
    item int,
    value int
)

insert into #item3 values
(1,100),
(2,200),
(3,300),
(4,400)

;with cte as (
    select *, t=1 from #item1
    union all
    select *, t=2 from #item2
    union all
    select *, t=3 from #item3
),
cte1 as (
    select
        *,
        rn = row_number() over ( partition by item order by t )
    from
        cte
)
select
    item, value
from
    cte1
where
    rn = 1


drop table #item1
drop table #item2
drop table #item3
票数 1
EN

Stack Overflow用户

发布于 2016-05-20 22:03:20

不创建表(临时表或其他表):

代码语言:javascript
运行
AI代码解释
复制
select
 M.item  --Select unique item from Master list
 ,coalesce(
  (select price from T1 where T1.item = M.item),
  (select price from T2 where T2.item = M.item),
  (select price from T3 where T3.item = M.item)
 )  --Cascade of prices per table
from 
  (select * from T1
  union
  select * from T2
  union 
  select * from T3) M  --Creating Master list of items and prices
group by item  --ensuring that we only pull unique items 

我认为这是一个有趣的问题,我知道这可以在一个查询中完成。其他的答案也很棒!只是调味一下

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37359249

复制
相关文章
Android - 使用Intent在活动之间穿梭
Intent有多个构造函数的重载,其中一个 Intent(Context packageContext,Class<?>cls)
博博1998
2022/04/25
5340
【Android基础】利用Intent在Activity之间传递数据
前言: 上一篇文章给大家聊了Intent的用法,如何用Intent启动Activity和隐式Intent,这一篇文章给大家聊聊如何利用Intent在Activity之间进行沟通。 从一个Activity获取返回结果: 启动一个Activity不仅仅是startActivity(Intent intent)一种方法,你也可以通过startActivityForResult()启动一个Activity并且在它退出的时候收到一个返回结果。 比如,你可以调用系统相机在你的应用中,拍了一张照片,然后返回到你的Acti
程序员互动联盟
2018/03/14
1.6K0
使用Intent在活动之间穿梭
Intent是Android中各组件进行交互的一种重要方式,它不仅可以指明当前组件想要执行的动作,还可以在不同组件之间传递数据.
Dream城堡
2018/12/12
6140
ChatGPT被玩坏了
原理就不展开说了,因为我也不懂,写出来估计大家也都看不懂,就简单复制一段网上的介绍:
Crossin先生
2023/03/06
5410
ChatGPT被玩坏了
android fragement之间互相传递参数
在Activity中加载Fragment的时候、有时候要使用多个Fragment切换、并传值到另外一个Fragment、也就是说两个Fragment之间进行参数的传递、查了很多资料、找到两种方法、一种是通过共同的Activity传递、这种方法是在Activity里面添加一个字段、来临时保存要一些值。
再见孙悟空_
2023/02/10
6490
Android Activity之间的数据传递
在Android中,如果我们要通过一个Activity来启动另一个Activity,可以使用 startActivity(Intent intent)方法来传入一个Intent对象,这个Intent对象我们可以精确的指定我们需要跳转的Activity上,或者通过Intent对象来指定我们要完成的一个action操作,同时我们可以通过intent来携带一些值,进而来Activity见跳转的时候也可以把值传过去。
233333
2021/04/09
1.8K0
Android Activity之间的数据传递
[android] 在不同的activity之间传递数据
添加<TextView/>控件,设置控件内容水平居中,android:gravity=”center_horizontal”
唯一Chat
2019/09/10
2.3K0
[android] 在不同的activity之间传递数据
Android Activity之间的数据传递【转载】
在目标Activity【Main2Acitivity】销毁时,想让它可以回传数据给上一个Activity,这样需要改写前面的代码: 1、设置一个请求码标识当前Activity,让它跳转到目标Activity【Main2Activity】,
_DIY
2020/12/09
1.1K0
Clubhouse已经被玩坏了
Clubhouse这几天火到爆炸,为了跟上时代的步伐,我在2月2日安装了Clubhouse,费劲心血搞到一个邀请码,终于进去了。
ImportSource
2021/03/07
4590
结构体数组在函数之间传递数据
明的数组,进行函数调用时,实参将数组名中存放的数组首地址传递给形参数组名。这样,实参数组名和形参名代表的是同一个结构体数组,因此在被调函数中对数组元素结构体变量的值进行修改后,回到主调函数通过实参数组名访问数组时,可以发现这个改变。
pigeon
2022/04/11
1.9K0
结构体数组在函数之间传递数据
postman系列(五):在不同接口之间传递数据
为了更灵活地构造请求以及处理响应数据,postman提供了Pre-request-Script和Tests,在这两个标签中可以编写js代码辅助测试。
冰霜
2022/03/15
2K0
postman系列(五):在不同接口之间传递数据
结构体类型数据在函数之间的传递
(3)结构体变量也可以作为函数的返回值,使用 return语句从被调函数返回一个结构体变
pigeon
2022/04/11
2.1K0
结构体类型数据在函数之间的传递
使用 Spring Cloud Bus 在微服务之间传递消息
Spring Cloud Bus 是 Spring Cloud 微服务框架中的一个组件,可以用于在微服务之间传递消息,从而实现微服务之间的协调和通信。
堕落飞鸟
2023/04/18
7090
Activity之间传递参数
发送 intent.setClass(Bmi.this, Report.class); Bundle bundle = new Bundle(); bundle.putString("KEY_HEIGHT", field_height.getText().toString()); bundle.putString("KEY_WEIGHT", field_weight.getText().toString()); intent.putExtras(bundle); startActivity(intent);
用户1075292
2018/01/23
5970
微信指数:是的,我被玩坏了
昨天,微信指数刚上线,朋友圈就被各种热词刷屏,有些真是让人哭笑不得、欲哭无泪……下面来看看你们都开了哪些脑洞。 ►自恋党:搜自己!搜自己!搜自己! 这名字快二十万了,这是一大波“网红”要火的节奏啊。 ►崩坏型:我是来找同类的 当朋友圈出现“穷”、“减肥”、“傻”这些词出现的时候,莫名地心中一痛……我也给这些指数贡献了一把啊,泪目~ ►idol哪家强?看微信指数 偶像的人气也是杠杠的。 ►运营狗:PK大号热度 当然,昨晚好多自媒体的小伙伴已哭晕在厕所,不比还好一比气死人,还能不能好好玩耍。 ►
腾讯大讲堂
2018/03/01
1.1K0
微信指数:是的,我被玩坏了
使用 Spring Cloud Bus 在微服务之间传递消息示例
下面是一个完整的示例,演示如何使用 Spring Cloud Bus 在微服务之间传递消息。该示例包含两个微服务,一个是消息发送者,另一个是消息接收者。
堕落飞鸟
2023/04/18
1.3K3
前端页面之间传递参数
跨页面传递参数 这里有假如传递一个参数,在另一个页面接收时,只需要js中写入如下代码: localhost:8080/index.jsp?id=1 function showWindowHref
微醺
2019/01/17
1.2K0
Spring Cloud Bus在服务之间传递自定义事件(一)
Spring Cloud Bus是Spring Cloud生态系统中的一个组件,用于在分布式系统中传递消息和事件。除了提供消息总线的基本功能之外,它还可以用于在服务之间传递自定义事件。
堕落飞鸟
2023/04/16
6580
点击加载更多

相似问题

"node_modules/@types/d3/index“中不存在‘'scale’和'svg‘

10

ngx-joyride中的./node_modules/ngx-joyride/assets/images/close.svg错误

10

Svg语义缩放不使用HTML中的SVG

11

防止node_modules在node_modules中的作用域

11

使用Nodejs从.svg文件中获取SVG

13
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文