Table of Contents
回复内容:
Home Backend Development PHP Tutorial PHP mysql 查询语句

PHP mysql 查询语句

Jun 06, 2016 pm 08:30 PM
mysql php

能一次性用数据库查询出来吗?

PHP mysql 查询语句

回复内容:

能一次性用数据库查询出来吗?

PHP mysql 查询语句

我很在意!!!!
1. first step

<code>SELECT t.* FROM (
SELECT t2.`etime` AS `日期`, 
    SUM(CASE WHEN t2.`epid` = t1_1.`pid` THEN t2.`ecost` ELSE 0 END) AS `A`,
    SUM(CASE WHEN t2.`epid` = t1_2.`pid` THEN t2.`ecost` ELSE 0 END) AS `B`,
    SUM(CASE WHEN t2.`epid` = t1_3.`pid` THEN t2.`ecost` ELSE 0 END) AS `C`,
    SUM(t2.`ecost`) AS `总计`
FROM table2 t2
LEFT JOIN table1 t1_1 ON t1_1.`pid` = t2.`epid` AND t1_1.`pid` = 1
LEFT JOIN table1 t1_2 ON t1_2.`pid` = t2.`epid` AND t1_2.`pid` = 2
LEFT JOIN table1 t1_3 ON t1_3.`pid` = t2.`epid` AND t1_3.`pid` = 3
GROUP BY t2.`etime`
) t
ORDER BY t.`日期` DESC

</code>
Copy after login

output:

<code>+------------+----+----+----+------+
| 日期       | A  | B  | C  | 总计 |
+------------+----+----+----+------+
| 2015-08-04 | 88 | 44 | 0  | 132  |
| 2015-08-03 | 88 | 77 | 66 | 231  |
+------------+----+----+----+------+
</code>
Copy after login
  1. second step
<code>SELECT IFNULL(tt.`日期`, '总计') AS `日期`, 
    SUM(tt.`A`) AS `A`, SUM(tt.`B`) AS `B`, SUM(tt.`C`) AS `C`,SUM(tt.`总计`) AS `总计`
    FROM (
    SELECT t.* FROM (
    SELECT t2.`etime` AS `日期`, 
        SUM(CASE WHEN t2.`epid` = t1_1.`pid` THEN t2.`ecost` ELSE 0 END) AS `A`,
        SUM(CASE WHEN t2.`epid` = t1_2.`pid` THEN t2.`ecost` ELSE 0 END) AS `B`,
        SUM(CASE WHEN t2.`epid` = t1_3.`pid` THEN t2.`ecost` ELSE 0 END) AS `C`,
        SUM(t2.`ecost`) AS `总计`
    FROM table2 t2
    LEFT JOIN table1 t1_1 ON t1_1.`pid` = t2.`epid` AND t1_1.`pid` = 1
    LEFT JOIN table1 t1_2 ON t1_2.`pid` = t2.`epid` AND t1_2.`pid` = 2
    LEFT JOIN table1 t1_3 ON t1_3.`pid` = t2.`epid` AND t1_3.`pid` = 3
    GROUP BY t2.`etime`
    ) t
    ORDER BY t.`日期` DESC
) tt
GROUP BY tt.`日期` WITH ROLLUP
</code>
Copy after login

output:

<code>+------------+-----+-----+----+------+
| 日期       | A   | B   | C  | 总计 |
+------------+-----+-----+----+------+
| 2015-08-03 | 88  | 77  | 66 | 231  |
| 2015-08-04 | 88  | 44  | 0  | 132  |
| 总计       | 176 | 121 | 66 | 363  |
+------------+-----+-----+----+------+
</code>
Copy after login

附原始数据表:

<code>mysql> select * from table1;
+-----+-------+
| pid | pname |
+-----+-------+
|   1 | A     |
|   2 | B     |
|   3 | C     |
+-----+-------+
mysql> select * from table2;
+-----+------------+------+-------+
| eid | etime      | epid | ecost |
+-----+------------+------+-------+
|   1 | 2015-08-03 |    1 |    88 |
|   2 | 2015-08-03 |    2 |    77 |
|   3 | 2015-08-03 |    3 |    66 |
|   4 | 2015-08-04 |    1 |    55 |
|   5 | 2015-08-04 |    2 |    44 |
|   6 | 2015-08-04 |    1 |    33 |
+-----+------------+------+-------+
6 rows in set
</code>
Copy after login

总感觉数据哪里有问题,是题主算错了,还是我算错了。

要做转置,处理起来相当的麻烦,基本思路是先用一个SQL查出列(A、B、C等),再循环,生成另一个SQL,再执行生成的SQL得到结果……太麻烦不写了,自己百度搜转置

简单的方法就是用一般的SQL统计查询,然后再在程序里来拼出你想要的表。

表1为主表 左联接加入表2

SELECT b.etime,a.pname,SUM(b.ecost) as sum_cost FROM table1 as a,table2 as b WHERE a.pid=b.epid GROUP BY b.etime,b.epid
执行后结果如图:
PHP mysql 查询语句

拿回来自己再算总计。

楼主的图画得不错,差点把我绕进去了...
select * from ( select * from table2 left join table1 on table2.epid =table1.pid order by eid asc,etime asc) as sumTable group by etime,eid;

panme etime ecost
A 08-04 x
A 08-05 x
B 08-04 x
B 08-05 x

好了,到了这步,楼主不会用php转成那种格式吗?要用sql也可以,不过也是需要一样的逻辑,PHP难道不比sql好使吗?PHP是世界上最好的语言喔

SELECT etime,SUM(IF(epid=1,ecost,0)) AS A,
SUM(IF(epid=2,ecost,0)) AS B,
SUM(IF(epid=3,ecost,0)) AS C, SUM(ecost) AS Total
FROM mytable GROUP BY etime;

没测试。

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

How to fix mysql_native_password not loaded errors on MySQL 8.4 How to fix mysql_native_password not loaded errors on MySQL 8.4 Dec 09, 2024 am 11:42 AM

One of the major changes introduced in MySQL 8.4 (the latest LTS release as of 2024) is that the &quot;MySQL Native Password&quot; plugin is no longer enabled by default. Further, MySQL 9.0 removes this plugin completely. This change affects PHP and other app

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

How do you parse and process HTML/XML in PHP? How do you parse and process HTML/XML in PHP? Feb 07, 2025 am 11:57 AM

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

PHP Program to Count Vowels in a String PHP Program to Count Vowels in a String Feb 07, 2025 pm 12:12 PM

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

7 PHP Functions I Regret I Didn't Know Before 7 PHP Functions I Regret I Didn't Know Before Nov 13, 2024 am 09:42 AM

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

The page is blank after PHP is connected to MySQL. What is the reason for the invalid die() function? The page is blank after PHP is connected to MySQL. What is the reason for the invalid die() function? Apr 01, 2025 pm 03:03 PM

The page is blank after PHP connects to MySQL, and the reason why die() function fails. When learning the connection between PHP and MySQL database, you often encounter some confusing things...

Top 10 PHP CMS Platforms For Developers in 2024 Top 10 PHP CMS Platforms For Developers in 2024 Dec 05, 2024 am 10:29 AM

CMS stands for Content Management System. It is a software application or platform that enables users to create, manage, and modify digital content without requiring advanced technical knowledge. CMS allows users to easily create and organize content

See all articles