Magento 数据库EVA

简介:

实体,属性和值(EVA)数据库架构排在第一,非常难以把握。EVA结构缺少文档,大部分的人还不知道EVA结构的,对magento都的好处、重要性以及适合性。在这篇文章我要介绍EVA是怎么工作的,为什么他有效,看了这边文章对magento的开发者来说是很有好处的。为了更好的理解这边文章,我建议使用phpmyadmin等数据库工具。


什么是EVA
EVA代表实体,属性和值。让我们看看它的每一部分,试着更好的了解它。
实体
实体代表等产品,种类,客户和订单Magento的数据项。每个实体(产品,类别等)都会有它的数据库中的实体记录。
属性(attribute_code)
该属性表示数据项属于一个实体。例如,产品实体,如名称,价格,地位和更多的属性。

该值是最简单的理解,因为它是简单地链接到一个属性的值。
为了更好地理解这一点,让我们考虑产品的实体。每个产品的实体将有一个属性,一个是属性名称系列。每一种产品将有一个属性名称值(和所有其他属性)。

EVA是怎么工作的 ?
让我们用一个产品表作为例子。比起将所有的数据存取在一个表格中,magneto将信息分开存储在多张表格中。
在这种层次结构的顶部表是 catalog_product_entity. 如果你在phpMyAdmin看看这个表,你会看到它包含了产品的简单基本资料,也没有出现任何有用的信息,包括SKU!幸运的是,使用此表是有可能建立从属性和值表的完整的产品记录。
要开始构建一个完整的产品记录,您将需要开始加入到产品实体的属性表。你这样做之前,看一下名为eav_attribute的表。eav_attribute是存储属性的主要表,用于存储所有不同的实体的属性(产品,客户,订单,分类等)。Magento的怎么知道哪一个属性属于一个产品,或者属于一个类别?由于通常是与Magento情况下,每一个实体 (产品,客户,订单,分类等) 都有一个 entity_type_id.要了解这一点,回去 catalog_product_entity 查找entity_type_id 这个字段.在该表中每个记录的值应该是4,因为这已被列为指定产品entity_type_id。如果你看看 catalog_category_entity你将看到另一个不同的 entity_type_id。使用这个值和属性代码,它可以为一个产品或任何实体加载属性。找到attribute_code对应的attribute_id和backend_type,如果backend_type不为空,就是用的catalog_category_entity_{backend_type}表,为空就是catalog_category_entity。通过attribute_id,catalog_category_entity中的entity_id可以找到莫一条纪录的值

为什么要使用EVA?
EAV 是因为它比一般规范化的数据库结构扩展性更好。开发人员无需修改数据库结构的核心就可以为任何实体(产品,品类,客户,订单等)添加属性。当建立一个自定义属性的时候,不用为保存这个属性去建立逻辑结构,因为它已经被建立到数据库模型中;只要数据集和属性已经建立,该模型将被保存!

EAV的缺点是什么?
EAV一个主要缺点是它的速度。因为实体数据如此支离破碎,创造了整个实体记录需要大量的表联接。幸运的是,在瓦瑞恩团队有一个很好的缓存系统实施,允许开发者缓存不经常改变的资料。
EAV的另一个问题是它学习有曲线性, 这样很多初级开发人员在了解到它的的简单之前就已经放弃了。虽然没有此快速修复,希望这篇文章将有助于人们开始解决这个问题。

结论
实体,属性,价值是一个伟大的数据库结构,是Magento成功的一个关键部分,开发人员了解如何运作是非常重要的。这方面的知识也有很多应用,我相信如果你的Magento工作时间足够长,你会碰到一些!

Java代码   收藏代码
  1. SELECT `e`.entity_id AS customer_id,`e`.email,_table_billing_name.value AS realname,_table_billing_addree.value AS address,  
  2. _table_billing_province.value as province,_table_billing_city.value AS city,_table_billing_postcode.value AS postcode  
  3. FROM `customer_entity` AS `e`   
  4. LEFT JOIN `customer_entity_int` AS `_table_default_billing` ON (`_table_default_billing`.`entity_id` = `e`.`entity_id`) AND (`_table_default_billing`.`attribute_id` = '7')  
  5. LEFT JOIN `customer_address_entity_varchar` AS `_table_billing_name` ON (`_table_billing_name`.`entity_id` = `_table_default_billing`.`value`) AND (`_table_billing_name`.`attribute_id` = '9')   
  6. LEFT JOIN `customer_address_entity_varchar` AS `_table_billing_postcode` ON (`_table_billing_postcode`.`entity_id` = `_table_default_billing`.`value`) AND (`_table_billing_postcode`.`attribute_id` = '14')   
  7. LEFT JOIN `customer_address_entity_varchar` AS `_table_billing_province` ON (`_table_billing_province`.`entity_id` = `_table_default_billing`.`value`) AND (`_table_billing_province`.`attribute_id` = '12')   
  8. LEFT JOIN `customer_address_entity_varchar` AS `_table_billing_city` ON (`_table_billing_city`.`entity_id` = `_table_default_billing`.`value`) AND (`_table_billing_city`.`attribute_id` = '15')   
  9. LEFT JOIN `customer_address_entity_text` AS `_table_billing_addree` ON (`_table_billing_addree`.`entity_id` = `_table_default_billing`.`value`) AND (`_table_billing_addree`.`attribute_id` = '16')   
相关文章
|
消息中间件 Java Shell
在CentOS7上安装RocketMQ 4.8.0
本文是博主在CentOS7上安装RocketMQ 4.8.0的记录,希望对大家有所帮助。
1118 0
|
机器学习/深度学习 传感器 自动驾驶
未来之路:大模型技术在自动驾驶的应用与影响
本文深入分析了大模型技术在自动驾驶领域的应用和影响,万字长文,慢慢观看~ 文中首先概述了大模型技术的发展历程,自动驾驶模型的迭代路径,以及大模型在自动驾驶行业中的作用。 接着,详细介绍了大模型的基本定义、基础功能和关键技术,特别是Transformer注意力机制和预训练-微调范式。 文章还介绍了大模型在任务适配性、模型变革和应用前景方面的潜力。 在自动驾驶技术的部分,详细回顾了从CNN到RNN、GAN,再到BEV和Transformer结合的技术迭代路径,以及占用网络模型的应用。 最后,文章重点讨论了大模型如何在自动驾驶的感知、预测和决策层面提供赋能,突出了其在该领域的重要性和影响力。
2390 56
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
1056 1
|
Web App开发 数据可视化 测试技术
Selenium Headless模式:无头浏览器的使用与优势
Selenium Headless模式是无界面的自动化测试方式,适用于Chrome和Firefox等浏览器,提供更快的速度、更高的隐秘性和资源节省。在Python中启用该模式,需导入Options并设置相关参数。示例代码展示了如何在无头模式下访问网站、执行点击和输入操作。这种模式提升了测试效率和稳定性,尤其适合大规模测试和CI环境。
|
机器学习/深度学习 人工智能 算法
人工智能在机器人编程与自动化控制中的应用与发展
人工智能在机器人编程与自动化控制中的应用与发展
1014 0
|
数据采集 Java 数据库连接
项目经验还写外卖和商城?来看看异构数据源数据流转服务 DatalinkX
你是否马上准备秋招、春招但没有项目经验,总觉得竞争力低 你是否一直浸泡在增删改查的业务代码,恼火技术成长过慢 你是否厌倦了XX学院、XX商城、XXRPC框架等网红项目 你是否想接触一线互联网公司项目架构与前沿技术栈 来跟我一起从零搭建基于Flink的异构数据源同步服务
928 0
|
网络协议 中间件 编译器
C语言的应用场景
C语言的应用场景
固态硬盘寿命天梯 2023.3
固态硬盘寿命天梯 2023.3
572 0
|
JavaScript
Ubuntu20安装nodejs和npm并切换阿里源
Ubuntu20安装nodejs和npm并切换阿里源
1290 1
Ubuntu20安装nodejs和npm并切换阿里源