我想使用4个表获取数据。 名单表的使用多个表优化方式的查询结果
- 数字
- 电话
- ref_label_no
- 标签
我想获取没有来电的号码附有特定标签的数据。 这里是表格。
号码表:
select id,uuid,number from numbers limit 1;
+----+--------------------------------------+------------+
| id | uuid | number |
+----+--------------------------------------+------------+
| 1 | ed268b05-758e-44fd-b429-8d5223651814 | 1234561222 |
+----+--------------------------------------+------------+
调用表
mysql> select id,uuid,did from calls limit 2;
+----+-------------------------------------+------------+
| id | uuid | number |
+----+-------------------------------------+------------+
| 1 | ddddass-b810-4f23-7456-8ff56efab080 | 1234561222 |
| 2 | dddddd-b810-4f23-7456-8ff56efab080 | 123456789 |
+----+-------------------------------------+------------+
2 rows in set (0.02 sec)
ref_label_no表
mysql> select uuid,number_uuid,label_uuid from ref_label_no limit 1;
+--------------------------------------+--------------------------------------+--------------------------------------+
| uuid | number_uuid | label_uuid |
+--------------------------------------+--------------------------------------+--------------------------------------+
| 7a5e1b6e-0194-4993-8d78-5f7a1b60c7d2 | ed268b05-758e-44fd-b429-8d5223651814 | 7262b06e-9263-4825-8411-4c107104a60b |
+--------------------------------------+--------------------------------------+--------------------------------------+
1 row in set (0.00 sec)
标签表
mysql> select uuid,name from labels limit 1;
+--------------------------------------+-------+
| uuid | name |
+--------------------------------------+-------+
| 7262b06e-9263-4825-8411-4c107104a60b | INDIA |
+--------------------------------------+-------+
1 row in set (0.00 sec)
现在我想导致像总接来电号码。[这个输出,我需要]
mysql> select uuid,name from labels limit 1;
+--------------------------------------+-------+
| Number | Total_calls |
+--------------------------------------+-------+
| 13456789 | 2 |
+--------------------------------------+-------+
1 row in set (0.00 sec)
我做了下面的查询,但没有成功也花费过多时间来响应。
select count(*) as Total_calls,calls.number as did,labels.name,calls.created_at as callstart from calls, labels JOIN ref_label_no ON labels.uuid = ref_label_no.label_uuid JOIN numbers ON numbers.uuid = ref_label_no.number_uuid where labels.name="INDIA" group by calls.number;
任何意见或建议?
不'ref_label_no'表起到什么作用?为什么你在使用UUID时似乎还在这些表上有一个自动增量列。如果使用UUID,则不需要自动增加 – e4c5
ref_label_no表包含所有参考值(如数字标签和数字表uuid),我们正在使用不基于主键的uuid的参考值。 –
对不起,评论不是很清楚 – e4c5