首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >从第二个表访问sql显示值

从第二个表访问sql显示值
EN

Stack Overflow用户
提问于 2015-01-01 08:14:27
回答 3查看 109关注 0票数 0

我仍在积极学习MS /sql(需要符合Office 2003 )。我已经尽我所能把事情简化了。

我有下表(Main),包括两个字段(Ax和Ay),它扩展到数千条记录。这是主数据库,需要搜索:

表:主表

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Ax  Ay
1   6
5   9
3   3
    7
5   5
7   2
2   
4   4
    3
6   5
7   6

等等..。上面的空白条目只是空值。Ax和Ay值可以出现在这两个字段中。

还有一个名为Afull的表,该表包含两个名为Avalid和Astr的字段:

表: Afull

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Avalid  Astr
1
2
3
4
5
6
7
8
9

字段Astr在每次运行开始时初始化为Null。

此表的第一个用途是将Ax和Ay的所有有效值存储在Avalid字段中。第二个用途是允许用户选择搜索标准。为此,在用户搜索表单中将表Afull作为子窗体添加。然后,用户将任何值>0输入到要搜索的值旁边的Astr中,从而选择要搜索的A有效值。

然后构建一个sql查询字符串,其目的是返回包含用户选择的A有效值的任何“置换”的所有记录:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT Main.Ax,Main.Ay
FROM Main
WHERE (Main.Ax In(uservalues) OR Main.Ax Is Null) AND (Main.Ay In(uservalues) OR Main.Ay Is Null)

“uservalue”转换为要搜索的有效值列表。这是很好的,并按预期工作(双空记录不存在)。

问题:I希望在结果中包含Astr值本身-- Astr值的一个字段和Astr值的一个字段。我尝试了一些方法,包括在SELECT语句中添加以下内容:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
strSQL = strSQL & ",IIF((Main.Ax In(uservalues)),Afull.Astr AS Axstr"
strSQL = strSQL & ",IIF((Main.Ay In(uservalues)),Afull.Astr AS Aystr"
strSQL = strSQL & "FROM Main,Afull"

...but,这不起作用。是否有相对简单的方法来达到这一点?

最终,我还将使用Astr值对升序进行排序。将Astr视为所选A有效值的“强度”。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-01-01 11:01:09

换句话来说,用户可以选择Ax & Ay的值,您只想返回Ax和Ay都在所选值列表中的记录,或者其中任何一个值可能为null,但不是两者都是空的。

现在,您要为Ax和Ay添加Astr。您可以使用如下所示的与共同相关的子查询,或者您可以两次连接到Afull,一次在Ax = Avalid上,一次在Ay = Avalid上。

如果要构建类似于示例中的SQL字符串,也要检查方括号。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT 
    Main.Ax,
    Main.Ay,
    (select Astr from Afull where Avalid = Main.Ax) as AxStr,
    (select Astr from Afull where Avalid = Main.Ay) as AyStr
FROM Main
WHERE (Main.Ax In(uservalues) OR Main.Ax Is Null) 
AND (Main.Ay In(uservalues) OR Main.Ay Is Null)
票数 1
EN

Stack Overflow用户

发布于 2015-01-01 15:52:54

不管哪种方法在一天结束时起作用,但这里有一种选择,它基本上为第一个计算为true的表达式选择了值。如果A?Str为null或小于零,则使用零值,以便您只需将这两个结果相加。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Switch(AxStr>=0, AxStr,AxStr<0,0,isnull(AxStr),0) + Switch(AyStr>=0, AyStr,AyStr<0,0,isnull(AyStr),0)
票数 1
EN

Stack Overflow用户

发布于 2015-01-01 13:02:34

谢谢你,GB,非常欣赏和完美的工作。问题中缺少的右括号也是固定的,并且Axstr Aystr ->提高了可读性AxStr AyStr注意到(突出强度方面)。

SELECT语句的扩展以获取AxStr+AyStr的总数,即,AxStr+AyStr as TOTAL只有在各自的Main.Ax和Main.Ay都具有非空值时才能工作。

由于主表中的Null值是可允许的,所以我扩展了SELECT语句以获得AxStr+AyStr的总数,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
strSQL = strSQL & ",IIF(AxStr>0 AND AyStr>0,AxStr+AyStr,IIF(Main.Ax Is Null,AyStr,
                    IIF(Main.Ay Is Null,AxStr,0))) AS AStrTOTAL"
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27732416

复制
相关文章
GoogleMaps api for javascript demo 动态按顺序加载marker
@{ } <!DOCTYPE html> <html lang="zh"> <head> <meta name="viewport" content="initi
阿新
2018/04/12
8040
JavaScript 将对象数组按字母顺序排序
Chrome、IE、Edge、Firefox、Safari、Opera 等 都支持 sort() 方法。
唐志远
2023/07/26
6330
JavaScript 将对象数组按字母顺序排序
JavaScript 将对象数组按字母顺序排序
1.if条件语句 + sort() 2.localeCompare() + sort() 3.Collator() + sort()
唐志远
2023/08/01
2610
JavaScript 将对象数组按字母顺序排序
junit方法按顺序执行
选定版本,直接加注解
IT云清
2021/12/06
1.3K0
junit方法按顺序执行
sql按顺序去重
参考博客: https://blog.csdn.net/qtvb1987/article/details/42081585
周杰伦本人
2022/10/25
8450
sql按顺序去重
数组按指定顺序排序
数组排序可以直接使用 sort() 方法,可以对数组按规律排序。 但如果指定一个没有规律的顺序进行排序呢? 同样可以使用  sort() 方法: const data = [   { name: '张三', code: 'zs' },   { name: '王五', code: 'ww' },   { name: '赵七', code: 'zq' }, ]; data.sort((star, next) => {   const sortList = ['zq', 'zs', 'ww']   return 
德顺
2022/06/12
2.7K0
HTML加载顺序
完成了若干个基于WEB的项目, 也了解了从前端的js,css,html到后端python/php等, 二者如何交互, 最终浏览器如何执行, 这些在心里也已经很明确了. 不过一个问题一直萦绕在心中,那就是:
用户7657330
2020/08/14
1.9K0
vue for循环中按顺序axios请求拿到每条数据对应的状态
在循环数组的时候基于每个对象中的某个参数来进行数据请求,获取当前对象对应的数据状态 实现方法基于最新的es6中的async await 来实现 首先要把对应的Promise方法进行一个封装
李维亮
2021/07/08
1.9K0
实现线程按顺序输出ABC
线程按顺序输出ABC 实现描述:建立三个线程A、B、C,分别按照顺序输出十次ABC 首先建立一个方法,按照条件进行输出 class PrintABC{ private int index=0; public synchronized void print(int n) { // TODO Auto-generated method stub try { while(index!=n) { wait(); } if(index==0) { System.out.
呆呆
2021/10/06
7810
JavaScript 按值传递 & 按引用传递
其次,对象的比较并非值的比较:对象的比较均是引用的比较,当且仅当它们引用同一个基对象时,它们才相等。     即使两个对象包含同样的属性和相同的值,它们也是不相等的。各个索引元素完全相等的两个数组也不相等
书童小二
2018/09/03
3.8K0
Javascript - 事件顺序
原文标题:Javascript - Event order 原文链接:https://www.quirksmode.org/js/events_order.html Netscape 4 只支持事件捕获,Explorer只支持事件冒泡。Netscape 6和 Konqueror冒泡和捕获均支持,但Opera 和iCab冒泡和捕获均不支持。 在介绍事件的那篇文章(文章链接:https://www.quirksmode.org/js/introevents.html)中,我提了个看起来比较难以理解的问题:“
崔庆才
2018/06/25
1K0
hive-行转列按顺序合并
目录 一、背景 二、实现 1.建表ddl 2.示例数据 3.按顺序合并 4.按顺序合并结果 5.可以看到最后一条最长的才是我们需要的数据 6.结果 ---- ---- 一、背景 想实现行转列按顺序合并,但是impala不支持,故用hive实现 二、实现 1.建表ddl create table a( id bigint comment '主键', type bigint comment '分类', start_time bigint comment '开始时间,时间戳', end_time big
chimchim
2022/11/13
2.1K0
hive-行转列按顺序合并
java | 如何让线程按顺序执行?
本文使用了8种方法实现在多线程中让线程按顺序运行的方法,涉及到多线程中许多常用的方法,不止为了知道如何让线程按顺序运行,更是让读者对多线程的使用有更深刻的了解。使用的方法如下:
JavaFish
2019/10/16
6.5K0
Java类加载的顺序
那一年,呼延十又回想起被加载顺序支配的恐惧,笔试题上,好几个类,几个方法,几个输出语句,让你按照顺序写出输出.我真的是有一句….
呼延十
2019/07/01
1.3K0
java变量的加载顺序
学习编程思想 1 package com.test.java.classs; 2 3 /** 4 * Created by Administrator on 2015/12/7. 5 * 在类的内部,变量定义的顺序决定了初始化的顺序。 6 * 变量会在任何方法(包含构造器)被调用之前得到初始化 7 */ 8 public class Variable { 9 public static void main(String[] args) { 10 House
Ryan-Miao
2018/03/13
1.1K0
javascript按位异或(^)[通俗易懂]
大家好,又见面了,我是你们的朋友全栈君。<script type=”text/javascript”> var num1=25; var num2=3; alert(num1^num2);//输出: 26 ;对两个数值的二进制写法进行比较,只有当相同位置上的数字只有一个1时,才返回1,有两个1或者都是0则返回0,然后转换成十进制数值; </script>
全栈程序员站长
2022/09/06
8460
让线程按顺序执行 8 种方法
本文使用了8种方法实现在多线程中让线程按顺序运行的方法,涉及到多线程中许多常用的方法,不止为了知道如何让线程按顺序运行,更是让读者对多线程的使用有更深刻的了解。使用的方法如下:
业余草
2019/09/18
2K0
让线程按顺序执行 8 种方法
web.xml 组件加载顺序
在配置项目组件的过程中, 了解Tomcat加载组件顺序很有必要。 例如某些框架如Quartz的集群功能需要数据库的支持, 数据库的加载肯定要在框架组件加载之前。
用户1257393
2018/07/30
8020
web.xml 组件加载顺序
在配置项目组件的过程中, 了解Tomcat加载组件顺序很有必要。 例如某些框架如Quartz的集群功能需要数据库的支持, 数据库的加载肯定要在框架组件加载之前。
用户1257393
2018/07/30
8930
点击加载更多

相似问题

按顺序加载JavaScript脚本

64

按特定顺序获取api请求

22

JavaScript按顺序获取多个请求

11

如何强制JavaScript按顺序加载?

11

Javascript承诺按反向顺序加载

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

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

洞察 腾讯核心技术

剖析业界实践案例

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