我在 MySQL 中有 4 个这样的表
第一张表:学生
id Name roll final
1 vivek 22222 65000
2 abc 33333 50000
第二张表:打折
id gst_amount roll
1 5000 22222
2 6500 22222
3 15000 22222
4 6000 33333
第三张表:费用
id amount roll
1 15000 22222
2 5000 22222
3 5000 33333
第四张表:pdc
id amount roll
1 9250 22222
2 9250 22222
我想加入所有表,并希望将 pdc 和 fee 表中的金额总和以及 discount 中的 表和最终列值。gst_amount 总和
我试过这个查询。
SELECT student.roll, final, SUM(discount.gst_amount) AS total, SUM(fee.amount) AS fee, SUM(pdc.amount) AS pdc
FROM student
LEFT JOIN discount on student.roll = discount.roll
LEFT JOIN fee on fee.roll = student.roll
LEFT JOIN pdc on pdc.roll = student.roll
GROUP BY student.roll
它给我这个输出。
roll final total fee pdc
22222 65000 106000 120000 110000
33333 50000 6000 5000 NULL
我想要这个输出。
roll final total fee pdc
22222 65000 26000 20000 18500
33333 50000 6000 5000 NULL
最佳答案
您的原始查询正在计算重复的总和值。
我认为您可以理解将 count(1) 列添加到您的原始查询中。
以下是我的输出。
mysql> SELECT student.roll, count(1) as count
-> FROM student
-> LEFT JOIN discount on student.roll = discount.roll
-> LEFT JOIN fee on fee.roll = student.roll
-> LEFT JOIN pdc on pdc.roll = student.roll
-> GROUP BY student.roll
-> ;
+-------+-------+
| roll | count |
+-------+-------+
| 22222 | 12 |
| 33333 | 1 |
+-------+-------+
2 rows in set (0.00 sec)
基于这些,请运行如下sql。
我认为这个 sql 有改进的地方,但我现在已经得到了你预期的结果。
另外,您想要的输出总列中的 26000 是错误的,我认为 26500 是正确的。
SELECT
student.roll,
final,
SUM(discount.gst_amount) AS total,
SUM(fee.amount) AS fee,
SUM(pdc.amount) AS pdc
FROM
student
LEFT JOIN
(SELECT
roll, SUM(gst_amount) AS gst_amount
FROM
discount
GROUP BY roll) AS discount ON discount.roll = student.roll
LEFT JOIN
(SELECT
roll, SUM(amount) AS amount
FROM
fee
GROUP BY roll) AS fee ON fee.roll = student.roll
LEFT JOIN
(SELECT
roll, SUM(amount) AS amount
FROM
pdc
GROUP BY roll) AS pdc ON pdc.roll = student.roll
GROUP BY student.roll
关于php - 求和函数返回错误值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52677707/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试用ruby中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe