我有三个表,例如DATA,SATURATION,VALUE,其中:

CREATE TABLE DATA(
  data_id INT AUTO_INCREMENT,
  PRIMARY KEY(data_id)
);

CREATE TABLE VALUE(
  value_id INT AUTO_INCREMENT,
  data_id INT,
  sample INT,
  channel_1 DOUBLE,
  channel_2 DOUBLE,
  channel_3 DOUBLE,
  PRIMARY KEY (value_id),
  FOREIGN KEY(data_id) REFERENCES DATA(data_id)
);

CREATE TABLE SATURATION(
  saturation_id INT AUTO_INCREMENT,
  data_id INT,
  sample INT,
  channel_1 INT CHECK (channel_1 >= 0 AND channel_1 <= 1),
  channel_2 INT CHECK (channel_2 >= 0 AND channel_2 <= 1),
  channel_3 INT CHECK (channel_3 >= 0 AND channel_2 <= 3),
  PRIMARY KEY (saturation_id),
  FOREIGN KEY(data_id) REFERENCES DATA(data_id)
);


我查询像:

SELECT s.sample AS 'S Sample', s.channel_1 AS '#Ch_1 S', s.channel_2 AS '#Ch_2 ES', s.channel_3 AS '#Ch_3 ES',
  v.sample AS 'V Sample', v.channel_1 AS '#Ch_1 V', v.channel_2 AS '#Ch_2 V', v.channel_3 AS '#Ch_3 V'
FROM VALUE v
  LEFT OUTER JOIN SATURATION s
  ON v.data_id = s.data_id
  WHERE s.sample = v.sample AND s.data_id = 1;


如果一个序列中的样本数相等,则结果正常。但是我想要这样的东西:

-----------
| ES Sample | #Ch_1 ES | #Ch_2 ES | #Ch_3 ES | EV Sample | #Ch_1 EV | #Ch_2 EV | #Ch_3 EV |
-----------
| 1 | 1 | 0 | 1 | 1 | 114.5 | 10.2 | 114.5 |
-----------
| 2 | 0 | 0 | 1 | 2 | 114.5 | 10.2 | 114.5 |
-----------
| 3 | 0 | 0 | 1 | 3 | 114.5 | 10.2 | 114.5 |
-----------
| 4 | 1 | 0 | 1 | 4 | 114.5 | 10.2 | 114.5 |
-----------
| null | null | null | null | 5 | 114.5 | 10.2 | 114.5 |
-----------

How to do it? Normally without clause 's.sample = v.sample' i get this. I don't want store saturation and value in one table but this very simple and foolish solution I guess.

UPDATE:

Here's a query which produce result as I wanted (if I have more values in one serie than saturations):

SELECT v.data_id AS 'V ID', s.data_id AS 'S ID', s.sample AS 'S Sample', s.channel_1 AS '#Ch_1 S', s.channel_2 AS '#Ch_2 S', s.channel_3 AS '#Ch_3 S',
  v.sample AS 'V Sample', v.channel_1 AS '#Ch_1 V', v.channel_2 AS '#Ch_2 V', v.channel_3 AS '#Ch_3 V'
FROM SATURATION s RIGHT JOIN VALUE v ON v.sample = s.sample
WHERE (v.data_id = 1 OR s.data_id IS NULL) AND (s.data_id = 1 OR s.data_id IS NULL);

最佳答案

我将在数据,值和饱和度之间创建一个样本表。因此,一个数据将具有许多样本,每个样本将具有零个或一个值以及零个或一个饱和度记录

然后从该“样本”表驱动查询,将“ Value”和“ Saturation”连接在一起。

让我知道这是否没有道理,我会尽力澄清,但希望您明白我的意思。

关于mysql - SQL连接没有多行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40747288/

10-09 08:49