mysql嵌套选择代码_关于mysql:嵌套联合选择语句

是否可以对我的sql SELECT语句的结果进行分组而不创建临时表以对一条语句进行求和和分组? 我有一张表格,保存贷方帐户号和借方帐户号的借方和贷方总额。

并为相反的字段输入零,我在下面的联合选择语句下进行了第一个分组,我需要根据重复的帐户名称对输出求和

我可以很容易地获得相同的结果,还是必须加载它的临时表? 我的选择声明如下

select  journal_drname  AS ACCNAME, sum(amount) AS DEBT,0 as CREDIT

FROM JOURNAL GROUP BY journal_drname

UNION select  journal_crname  AS ACCNAME, 0 as DEBT,sum(amount) AS

CREDIT,

FROM JOURNAL GROUP BY journal_crname

返回数据,例如:

ACCNAME      DEBIT     CREDIT

--------   -------     ------

CASH        0           1,000

CASH        900          0

CASH        300          0

BANK        200          0

BANK        400          0

我可以在上方总结以下几项:

ACCNAME      DEBIT     CREDIT

--------   -------     ------

CASH        200          0

BANK        600          0

我想将这些结果与上述相同。

我试图避免使用临时表,但是如果这是唯一可行的方法,那么我想了解更多有关以这种方式使用临时表的信息。

我也尝试进行某种形式的联接和联合,但不满足条件,而且我也不知道该怎么做。

除非journal_drname中包含不寻常的字符,否则您的结果没有意义。

改写:每个现金名称和现金的贷方和借项值分别为0怎么办? 您提出的SQL否定了这种可能性。

是的,我有两种情况下的帐户名有时会记入贷方,在这种情况下,我必须将帐户名加载到journal_crname中,如果借记了相同的帐户名,则必须将其加载到journal_crname字段中,因此我在外部帐户名中加载了两列 journal_drname和journal_crname

正如您所说的,查询工作正常,让我们将联合查询称为表格

( ...... ) myTable

然后只需创建一个子查询即可获得最后一步

SELECT ACCNAME,

CASE WHEN SUM(CREDIT - DEBT) < 0 THEN - SUM(CREDIT - DEBT)

ELSE 0

END DEBT,

CASE WHEN SUM(CREDIT - DEBT) > 0 THEN   SUM(CREDIT - DEBT)

ELSE 0

END CREDIT

FROM ( ...... ) myTable

GROUP BY ACCNAME

该语句看起来很完美,但仍然给我错误消息,不接受最后一行" GROUP BY ACCNAME",我将继续检查并恢复thxs

是的,现在工作量增加了三倍

您发现错误了吗?

是的,我错过了将内部表别名myTable放的原因,这就是为什么。

如果每个子查询只需要一行,则删除group by:

select  'CASH' as ACCNAME, sum(amount) AS DEBT, 0 as CREDIT

FROM JOURNAL

UNION ALL

select  'BANK' as ACCNAME, 0 as DEBT, sum(amount) AS  CREDIT

FROM JOURNAL;

(注意:ACCNAME值可能相反。)

要点:对于这种类型的查询,应该使用UNION ALL而不是UNION。 除非您打算删除重复项,否则没有理由承担删除重复项的开销。

另外,除非accname字段中有不寻常的字符,否则您的原始查询应该已经起作用。

我喜欢它...但是我对",除非您打算删除重复项"感到困惑,根据定义,不能有重复项。 基于SQL。 CASH和BANK否定联合中的重复项,并且在内部,由于每行只有一行,因此不能有重复项。 也许您需要在联合的每个部分中的journal_drname的where子句,对于银行的一个子句,对于现金的子句。

@xQbert。。。 即使没有重复项,UNION总是会产生删除重复项的开销(我说"总是";但是我想某个地方的某些数据库可能会识别出某些短路重复项消除的特殊情况)。

关于什么:

select ACCNAME,

CASE WHEN sum(DEBT)>sum(CREDIT) THEN sum(DEBT)-sum(CREDIT) ELSE 0 AS DEBT,

CASE WHEN sum(DEBT)

FROM (

select  journal_drname  AS ACCNAME,

sum(amount) AS DEBT,

0 as CREDIT

FROM JOURNAL GROUP BY journal_drname

UNION

select journal_crname  AS ACCNAME,

0 as DEBT,

sum(amount) AS CREDIT,

FROM JOURNAL GROUP BY journal_crname

) group by ACCNAME

我相信mySql子查询必须具有别名才能工作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/498940.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jar中没有主清单属性_还在因 JDK 兼容问题发不同 JAR 包做兼容?MRJAR 了解一下?...

背景Java 9 版本中增强了Jar 包多版本字节码文件格式支持&#xff0c;也就是说在同一个 Jar 包中我们可以包含多个 Java 版本的 class 文件&#xff0c;这样就能做到 Jar 包升级到新的 Java 版本(新特性 API 使用)时不用强迫使用方为了使用新 Jar 包而升级自己的业务模块 Java …

java中哪些可以私有化_《Java基础学习笔记》JAVA修饰符之私有化(Private)

1&#xff0c;什么是private修饰符&#xff1f;private是权限修饰符&#xff0c;用于修饰类中的成员(成员变量&#xff0c;成员函数)。private修饰后的成员只在本类中有效。/* 例&#xff1a;* 将age私有化以后&#xff0c;类以外即使建立了对象也不能直接访问。* 但是人应用有…

python不定长参数_Python 函数参数之不定长参数(*args/**kwargs)、匿名函数 Lambda详解...

Python 调用函数时可使用的正式参数类型&#xff1a;必需参数 (位置参数)、关键字参数 (keyvalue)、默认参数 (keydefault)、不定长参数(可变参数)、强制位置参数(组合传参)Tips&#xff1a;有兴趣的还可以了解一下什么是形参&#xff1f;什么是实参&#xff1f;不定长参数 *a…

java第一天上班需要安装那些_明天第一天上班,应该带什么包啊

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼“下面拍卖的是一位道友在上古遗存下来的仙殿中得到的一盒炫迈&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;”大厅中顿时一片嘈杂.......拍卖行的老者摆了摆手示意让大家静一静然后慢悠…

java代码例子_程序员快速弄清Java异常体系,拒绝痛苦编程,开发效率加倍

知己知彼方能百战不殆,在小编初学Java时候特别怕程序报异常,经常会因为异常不知所措,相信这个问题应该是所有 初学者都会有的心理感受;如果你也有这种感受,那么只有一种解决方法: 迎难而上,攻克Java异常体系,长痛不如短痛,只要清楚了Java的异常体系,就不会再有这种感受了。下面…

java多条件判断_Java基础教程,第七讲,条件控制、循环语句、数组

学完此次课程&#xff0c;我能做什么&#xff1f;学完此次课程我们将掌握Java中的条件判断和多种循环语句&#xff0c;并且掌握数组的定义和初始化&#xff0c;以及几个常用的数组函数。学习此次课程&#xff0c;需要多久&#xff1f;10分钟课程内容和其他语言一样Java使用条件…

文件上传java前端怎么写_做一个文件上传,前端是ajax提交数据后台是java,这个错误怎么办...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼严重: Servlet.service() for servlet [dispatcherServlet] in context with path [/bazx] threw exception [Request processing failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to …

python对文件操作的相关函数_超全!python的文件和目录操作总结

文件的基本读写path rC:UsersBradyDocumentstmpwith open(path rdemo.txt, r, encodingutf-8) as f:content f.read()print(content)open()函数open(file, moder, buffering-1, encodingNone, errorsNone, newlineNone, closefdTrue, openerNone)Open file and return a cor…

qq机器人源码_基于Springcloud+vue+oAuth2.0全家桶模拟商城项目源码分享

项目介绍功能点&#xff1a;模拟商城&#xff0c;完整的购物流程、后端运营平台对前端业务的支撑&#xff0c;和对项目的运维&#xff0c;有各项的监控指标和运维指标。技术点&#xff1a;核心技术为springcloudvue两个全家桶实现&#xff0c;采取了取自开源用于开源的目标&…

java静态页面我都做不出_Java高并发:静态页面生成方案

提升网站性能的方式有很多&#xff0c;例如有效的使用缓存&#xff0c;生成静态页面等等。今天要说的就是生成静态页面的方式。这个也是我近期一直在搞的一个问题&#xff0c;近期在做使用html servlet做个人网站&#xff0c;为什么是这2个东西呢&#xff1f;1、直接用servlet…

python 工厂模式与单例模式_python基础单例模式 工厂模式 策略模式 观察者模式...

一、单例模式单例&#xff1a;单个实例&#xff0c;确保某个类只有一个实例存在举例&#xff1a;1、登录app&#xff0c;当前的登录对象&#xff0c;只能有一个2、音乐播放器&#xff0c;正在播放的歌曲类而言&#xff0c;只能有一个实例1 import my_util # 被导入的模块会从…

js sleep函数_简单而面试中又常见的知识点:JS执行机制

在开始讲解之前&#xff0c;我们先来看一段代码&#xff1a;console各位小伙伴觉得上面的结果输出会是多少呢&#xff1f;如果你没有了解过javascript的执行机制的话&#xff0c;上面的题目可能会让你崩溃。不过别着急&#xff0c;先往下看&#xff0c;我保证你看到最后&#x…

护卫神怎么增加php版本_护卫神php套件 php版本升级方法(php5.5.24)

最近小编开始学习研究win2008 r2的php环境配置&#xff0c;发现护卫神的php套件非常好用&#xff0c;安装简单&#xff0c;但是因为php版本不是最新的版本&#xff0c;所以就想将php升级下&#xff0c;因为新版的php修复了一些bug所以这里就分享下方法&#xff0c;需要的朋友可…

servlet中doget和dopost的区别_Servlet学习

一.HTTP协议浏览器 ----------------------------------------->服务器请求 http协议&#xff08;包含&#xff1a;1.请求行2.请求头3.空行4.请求实体&#xff09;url浏览器<-------------------------------------------服务器 响应htmlcssjsdata数据特点&#xff1a; 1…

python numpy dtype object_如何将(dtype = object)numpy数组值设置为Python列表,而不将numpy解释为值列表?...

我有一个dtype object数组,其中的值是Python列表或np.nan.我想用[无](不是无)替换np.nan的值.对于一个纯Python列表,我已经可以使用[x if(x不是np.nan)其他[无] for x in s],并且将数组转换为列表对我来说很好,但是出于好奇,我想知道如何使用numpy数组来完成这项工作.困难在于…

php curl跨域cookie_php使用curl带cookie访问一直失败求助

Launcher:感谢你在百忙中抽空帮我。刚才我做了个对比&#xff1a;1、使用Microsoft Network Monitor 监听apache发送的数据包2、使用Microsoft Network Monitor 截获ie登录目标后台3、使用Microsoft Network Monitor 截获firefox登录目标后台由第一点得到&#xff1a;cookie确实…

python如何用idle启动_Python从IDLE启动的方法

学习Python就要先学会安装和启动&#xff0c;目前Python的启动方法有两种&#xff0c;从IDLE启动是比较常见的&#xff0c;也是小码王老师今天要教大家的&#xff0c;广大家长、小朋友们一起来学习了解一下吧。在Start(开始)菜单中&#xff0c;可以看到“Python2.5”下面的“ID…

java xml 节点路径,SelectSingleNode使用XPath为已知良好的xml节点路径返回null

回答(9)2 years ago我强烈怀疑问题与名称空间有关 . 尝试摆脱名称空间&#xff0c;你会没事的 - 但显然这对你的实际情况没有帮助&#xff0c;我认为这个文件是固定的 .我不记得如何在XPath表达式中指定命名空间&#xff0c;但我确信这是问题所在 .编辑&#xff1a;好的&#x…

php fastcgi exp,nginx +phpfastcgi 环境下 导出excel文件,超时,数据被截断问题,解决...

nginx 错误日志显示&#xff0c;访问超时2015/09/16 07:18:43 [error] 2108#0: *6 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 192.168.138.7, server: localhost, request: "GET /test/index.php?mlists.e…

python爬虫软件安装不了_Mac os 下 python爬虫相关的库和软件的安装

由于最近正在放暑假&#xff0c;所以就自己开始学习python中有关爬虫的技术&#xff0c;因为发现其中需要安装许多库与软件所以就在这里记录一下以避免大家在安装时遇到一些不必要的坑。一. 相关软件的安装&#xff1a;1. homebrew:homebrew 是mac os系统下的包管理器由于功能齐…