Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/62.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/69.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 为了拥有可变列,单个表的“多个”联接的成本是多少_Mysql_Sql_Database_Query Optimization - Fatal编程技术网

Mysql 为了拥有可变列,单个表的“多个”联接的成本是多少

Mysql 为了拥有可变列,单个表的“多个”联接的成本是多少,mysql,sql,database,query-optimization,Mysql,Sql,Database,Query Optimization,我需要在Mysql数据库中有变量列。我使用了另一种方法,即有一个helpermeta_data表。我在元数据的每一行中存储变量列。元数据的结构是: CREATE TABLE IF NOT EXISTS `data_meta` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `data_id` int(11) DEFAULT NULL, `meta_key` varchar(200) CHARACTER SET utf8 DEFAULT NULL,

我需要在Mysql数据库中有变量列。我使用了另一种方法,即有一个helper
meta_data
表。我在
元数据的每一行中存储变量列。
元数据的结构是:

CREATE TABLE IF NOT EXISTS `data_meta` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `data_id` int(11) DEFAULT NULL,
  `meta_key` varchar(200) CHARACTER SET utf8 DEFAULT NULL,
  `meta_value` text CHARACTER SET utf8,
  PRIMARY KEY (`id`),
  KEY `data_id` (`data_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=347 ;
我需要查询一些变量列。所以我的问题是Mysql中这种声明的成本是多少:

select * 
from data
join data_meta as data_prov on (data.id=data_prov.data_id)
join data_meta as data_city on (data.id=data_city.data_id)
join data_meta as data_price on (data.id=data_price.data_id)
.
.
.
.
如果在现实世界中,这会导致我的查询速度非常慢,那么有没有其他方法可以使用
变量列


注意:数据和元数据都可以快速增长

如果数据索引正确,那么多个联接应该不会成为问题。在这种情况下,您需要在
data\u meta(data\u id,meta\u key)
甚至
data\u meta(data\u id,meta\u key,meta\u value)

顺便说一下,我想你把
meta_键
忘在逻辑之外了

select * 
from data
join data_meta as data_prov on (data.id=data_prov.data_id and data_prov.meta_key = 'prov')
join data_meta as data_city on (data.id=data_city.data_id and data_city.meta_key = 'city')
join data_meta as data_price on (data.id=data_price.data_id and data_price.meta_key = 'price')
假设每个键只有一个匹配项,也可以按如下方式执行查询:

select d.*,
       max(case when dm.meta_key = 'prov' then dm.meta_value end) as prov,
       . . .
from data join
     data_meta dm
     on d.id = dm.id
group by d.id;
如果您正在获取一个元键的值,这将很好。然而,MySQL倾向于以比聚合更快的速度进行连接,因此连接方法通常可能更快

编辑:


要使此查询快速工作,您需要能够快速查找元数据。在MySQL中,最好的方法是使用索引。这允许MySQL快速查找元数据中的值。其他数据库支持一种称为并行散列联接的技术,这也将加快查询速度(并行散列聚合将加快分组速度)。因为这些不是MySQL中的选项,所以您想使用索引。

您能解释更多关于索引影响的信息吗?我能在一个查询中自动获取所有meta_值吗?或者我唯一的方法就是每次都使用PHP创建查询?@MostafaShahverdy。您可以使用
group\u concat()
获取所有的元数据。