最新消息:Excel无乱码转CSV,由于工作原因很少更新博客和回复大家的评论,非常抱歉。

Magento 数据表结构 EAV模型详解

EAV : Entity – Attribute – Value的缩写,是数据库模型的一种,使用eav建模的好处是可以动态为数据模型增加或移除属性。

1.问题提出:

假设需要定义一个实体Customer的信息,通常我们只要定义一个表为customer,并定义相应的属性即可。倘若某天需要为customer增加一个新的属性如“毕业学校”,那么就需要更改表的结构。
如果使用EAV模型则不必改变表结构。

2.Magento的EAV模型定义:

在Magento中,EAV模型相关的表定义有:

1、eav_attribute               
2、eav_attribute_group         
3、eav_attribute_option        
4、eav_attribute_option_value  
5、eav_attribute_set           
6、eav_entity                  
7、eav_entity_attribute        
8、eav_entity_datetime         
9、eav_entity_decimal          
10、eav_entity_int              
11、eav_entity_store            
12、eav_entity_text             
13、eav_entity_type             
14、eav_entity_varchar  

现在让我来观察最重要的三张表
eav_entity_type,eav_entity_attribute,eav_attribute

1) eav_entity_type表用来定义实体的基本信息。

Sql代码
  1. mysql> select from  eav_entity_type where entity_type_id=1;  
  2. +—————-+——————+——————-+—————–+—————–+  
  3. entity_type_id entity_type_code entity_model      attribute_model entity_table    +—————-+——————+——————-+—————–+—————–+  
  4.              customer         customer/customer                 customer/entity  
  5. +—————-+——————+——————-+—————–+—————–+  

2). eav_entity_attribute表用来定义实体customer模型包含哪些属性

Sql代码
  1. mysql> select from eav_entity_attribute  where entity_type_id=’1′;  
  2. +———————+—————-+——————+——————–+————–+  
  3. entity_attribute_id entity_type_id attribute_set_id attribute_group_id attribute_id  
  4. +———————+—————-+——————+——————–+————–+  
  5.                                                                            
  6.                                                                            
  7.                                                                            
  8.                                                                            
  9.                                                                            
  10.                                                                            
  11.                                                                            
  12.                                                                            
  13.                                                                            
  14.                  10                                                        10  
  15.                  11                                                        11  
  16.                  12                                                        12  
  17.                  13                                                        13  
  18.                  14                                                        14  
  19.                  15                                                        15  
  20.                  16                                                        16  
  21. +———————+—————-+——————+——————–+————–+  

3), 由上表推出customer实体包含16个属性,下面的语句查看每个属性的具体定义

Sql代码
  1. mysql> select from eav_attribute where attribute_id<=16 and attribute_id>=1  
  2. +————–+—————-+——————+————–+  
  3. attribute_id entity_type_id attribute_code   backend_type  
  4. +————–+—————-+——————+————–+  
  5.                         website_id       static        
  6.                         store_id         static        
  7.                         created_in       varchar       
  8.                         prefix           varchar       
  9.                         firstname        varchar       
  10.                         middlename       varchar       
  11.                         lastname         varchar       
  12.                         suffix           varchar       
  13.                         email            static        
  14.           10              group_id         static        
  15.           11              dob              datetime      
  16.           12              password_hash    varchar       
  17.           13              default_billing  int           
  18.           14              default_shipping int           
  19.           15              taxvat           varchar       
  20.           16              confirmation     varchar       
  21. +————–+—————-+——————+————–+  

所以,使用上述的模型,一旦有CUSTOMER属性定义的添加和删除,只需要增加或删除eav_entity_attribute的记录即可

3.使用EAV模型
现在,在Magento系统注册一个新的用户,看看实例数据如何存放在数据库

Sql代码
  1. mysql> select from customer_entity             
  2. +———–+—————-+——————+————+——————–+  
  3. entity_id entity_type_id attribute_set_id website_id email               
  4. +———–+—————-+——————+————+——————–+  
  5.                                              koda.guo@gmail.com  
  6. +———–+—————-+——————+————+——————–+  
  7.   
  8. mysql> select from customer_entity_varchar     
  9. +———-+—————-+————–+———–+————————————-+  
  10. value_id entity_type_id attribute_id entity_id value                                
  11. +———-+—————-+————–+———–+————————————-+  
  12.                                        Koda                                 
  13.                                        Guo                                  
  14.                                        Default Store View                   
  15.                               12         2256e441b74ab3454a41c821f5de1e9d:9s  
  16. +———-+—————-+————–+———–+————————————-

从上表看到customer_entity和customer_entity_varchar用来存放相应属性的实际输入值。如:
Koda, Guo分别属性编号5,7即firstname和lastname实际值

和customer实体定义相对应的实例存放的相关表包括:

1、customer_entity            
2、customer_entity_datetime   
3、customer_entity_decimal    
4、customer_entity_int        
5、customer_entity_text       
6、customer_entity_varchar     

总结
了解Magento的EAV模型结构是扩展Magento必须的知识。其意义在于,我们常常需要扩展Magento某些实体的属性,或者创建自定义的eav模型实例。希望本文对你有所启示。

转载请注明:嗨酷哥,有你更酷! » Magento 数据表结构 EAV模型详解

与本文相关文章

发表我的评论

取消评论
表情 插代码

Hi,您需要填写昵称和邮箱!

  • 必填项
  • 必填项