如何连接两个表,然后显示一个表从另一个表收集的每个数据的总和值
首先,抱歉,如果我的问题标题听起来很愚蠢......我有下表。第一个表包含我的费用类型的名称,第二个表包含这些费用的金额和日期信息。如果您注意到下面的第二个表,有一个名为“ e_id ”的字段,它是第一个表中我的费用的相应 id 值。
第一个表名称:expense_type
id expense_name
1 Insurance
2 Interest Payment
3 Rent
4 Electricity
... and goes on like this (unlimited perhaps :))
第二个表名称:expense_details
id e_id amount date
1 3 1000 2011-12-11
2 1 500 2011-12-19
3 4 10 2011-11-21
4 3 1000 2012-01-12
... and goes on like this )
现在我的计划是从这两个表中获取所有值并生成如下结果。但由于第一个表有未知数量的信息(对我来说),我不知道如何编写查询(php 和 mysql)来生成这样的结果。
请您帮助我如何实现这一目标?
提前致谢:)
PS 仅供您参考,我正在使用 Codeigniter。
**For the Month: January 2011**
Insurance : 1000
Rent : 3453
Electricity : 546
Interest Payment : 546
---------------------------------
**Total Expenses**: 938949 /// this value is just for an example
First of all Sorry if my question title sounds stupid.... I have the following tables. The first table contains the name of my expenses type and the second table contains the information of amount and date of those expenses. If you notice the second table below there is a field called " e_id " which is the corresponding id value of my expenses from the first table.
First Table Name: expense_type
id expense_name
1 Insurance
2 Interest Payment
3 Rent
4 Electricity
... and goes on like this (unlimited perhaps :))
Second Table Name: expense_details
id e_id amount date
1 3 1000 2011-12-11
2 1 500 2011-12-19
3 4 10 2011-11-21
4 3 1000 2012-01-12
... and goes on like this )
Now my plan is to get all the values from these two tables and generate a result like following . But since the first table has unknown number of information (to me) I don't know how to write the query(both php and mysql) to generate such result.
Woud you please kindly help me on how to achieve this?
Thanks in Advance :)
P.S just for you information I am using Codeigniter.
**For the Month: January 2011**
Insurance : 1000
Rent : 3453
Electricity : 546
Interest Payment : 546
---------------------------------
**Total Expenses**: 938949 /// this value is just for an example
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
您可以
根据需要使用“然后”格式。注意
date
是用反引号括起来的,因为它也是 MySQL 中的一个函数。要更改月份,您只需执行
`date
>= 'yyyy-mm-01' ANDdate
< 'yyyy-(mm+1)-01'(除非
mm` 是 12 月...)。您也可以选择
或
2011 年 1 月(看看 这里),但我认为如果没有日期索引,速度会慢一些(当然,选择哪种方法取决于您要筛选的预期记录数量、数据库的设置方式,等等等等——但为什么不尝试几个版本,看看哪个适合您呢?)
You can use the
And then format as you wish. Note
date
is in backticks since it's also a function in MySQL.To change the month you just do
`date
>= 'yyyy-mm-01' ANDdate
< 'yyyy-(mm+1)-01'(unless
mm` is December...).You could alternatively do
or
for Jan 2011 (have a look here), but I reckon it's a bit slower if you don't have date indexed (of course which method you pick depends on the expected number of records you're sifting through, how the database is set up, etc etc -- but why not give a few versions a go and see what suits you?)
您可以在控制器或模型中执行此操作:
不是最优雅或最稳定的方法,但我希望这有助于您了解需要做什么。我想您可能还想按月细分总数。
You can do this in a controller, or model:
Not the most elegant, or stable method but I hope this helps give you the idea of what you need to do. You'll also probably want to break totals up by month I suppose.
当然,您可以设置任何日期范围,甚至可能是一个月,或者根本没有日期条件,以获得完整的报告。
它将每月汇总每种类型的费用(您将填写
month
且ed.e_id
= NULL - 这样您就知道这是该月的摘要),然后全职(月
和ed.e_id
= NULL)。输出将如下所示:
当然,当您看到
e_id
= NULL 时,您必须忽略粘性expense_name
有些人可能建议您只获取结果,然后使用 PHP 将它们求和,但它对于大型报告来说,这将是一个性能消耗。让 SQL 做它最擅长的事情(挖掘数据计数、求和等),让 PHP 做它最擅长的事情(渲染 HTML)。
当然,如果您正确设置了外键(这就是为什么 JOIN 比仅从两个表中选择并在 WHERE 子句中添加
id=e_id
更快)并且具有 < code>date 字段已索引。You can set any date range of course, maybe even one month, or no date condition at all, to get full report.
It will sum expenses for each type with summary every month (you will have
month
filled anded.e_id
= NULL - that way you know it's summury for the month) and then for full time (bothmonth
anded.e_id
= NULL).Output will be like this:
Of course you must ignore sticky
expense_name
when you seee_id
= NULLSome may suggest you just get results and then SUM them up with PHP, but it'll be a perfomance drain for large reports. Let SQL do what it does best (dig through data counting, summing, whatsoevering), and let PHP do what it does best (render HTML).
Of course SQl will reward you with even better performance if you have foreign keys set up correctly (that's why JOIN would work faster than just selecting from two tables and adding
id=e_id
in WHERE clause) and havedate
field indexed.