0

私は2つのテーブルを持っています:

CREATE TABLE `en_us` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `file_folder` varchar(6) DEFAULT NULL,
  `file_name` varchar(200) DEFAULT NULL,
  `file_type` varchar(200) DEFAULT NULL,
  `actual_word` varchar(200) DEFAULT NULL,
  `voice_type` tinyint(4) DEFAULT NULL,
  `note` text,
  `attention_bit` tinyint(4) DEFAULT '0',
  `no_file` tinyint(4) DEFAULT '1',
  `created` datetime DEFAULT NULL,
  `updated` datetime DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `file_name_location` (`file_name`,`file_type`,`file_folder`),
  KEY `file_name_idx` (`file_name`),
  KEY `actual_word_idx` (`actual_word`)
) ENGINE=InnoDB AUTO_INCREMENT=127961 DEFAULT CHARSET=utf8 |

CREATE TABLE `en_us_tags` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `fk_en_us_id` bigint(20) NOT NULL,
  `tag_text` varchar(200) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `tag_text_idx` (`tag_text`),
  KEY `fk_en_us_id` (`fk_en_us_id`),
  CONSTRAINT `en_us_tags_ibfk_1` FOREIGN KEY (`fk_en_us_id`) REFERENCES `en_us` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=139162 DEFAULT CHARSET=utf8

en_us_tagsに参加する左結合を行う必要がありen_us、一意のen_us行の数を取得する必要があります。

このクエリは、代わりに各グループの数を返すため、間違っています。

SELECT count(*) FROM audio.en_us 
LEFT JOIN audio.en_us_tags 
ON (audio.en_us.id = audio.en_us_tags.fk_en_us_id) 
GROUP BY (audio.en_us.id);

ヘルプ?

EDIT 1:(Rogue) それは間違っています。合計数が必要です。
これが get の出力です。

mysql> SELECT DISTINCT COUNT(audio.en_us.id) FROM audio.en_us LEFT JOIN audio.en_us_tags ON audio.en_us.id = audio.en_us_tags.fk_en_us_id GROUP BY audio.en_us.id;
+-----------------------+
| COUNT(audio.en_us.id) |
+-----------------------+
|                     2 |
|                     1 |
|                     3 |
|                     4 |
|                     5 |
|                     6 |
|                     7 |
|                     9 |
+-----------------------+

編集2:サブクエリアプローチは機能しますが、一時テーブルが構築されるため、IMHOは少し遅くなります:

SELECT COUNT(*) 
FROM (SELECT audio.en_us.id FROM audio.en_us 
LEFT JOIN audio.en_us_tags 
ON audio.en_us.id = audio.en_us_tags.fk_en_us_id 
GROUP BY audio.en_us.id) as test;
+----------+
| COUNT(*) |
+----------+
|   127960 |
+----------+
1 row in set (0.00 sec)

編集 3: サブクエリを使用せずに GROUPS カウントを取得する方法を知っている人はいますか? 100,000 行があるかのように、一時テーブルを作成するサブクエリは高価になる可能性があります。

4

1 に答える 1

1

行の一意のカウントについては、次の行に沿って何かを試してください。

SELECT COUNT(id)
FROM (
   SELECT DISTINCT *
   FROM audio.en_us
   LEFT JOIN audio.en_us_tags
   ON audo.en_us.id = audio.en_us_tags.fk_en_us_id
) t1;

これは、一意の audio.en_us 行の数のみを返します。

于 2013-10-17T17:10:31.903 に答える