magento 数据结构

首先要知道是EAV模式,这种结构要比普通数据结构更容易扩展,但是带来的就是查询速度慢,好在magento的缓存机制不错
最重要的3张表eav_entity_type,eav_entity_attribute,eav_attribute

eav_entity_type表用来定义实体的基本信息
比如entity_type_id = 1是customer实体

eav_entity_attribute表用来定义实体模型包含哪些属性(当然这里还涉及到set和group)
select * from eav_entity_attribute where entity_type_id=1;取出customer有哪些属性

eav_attribute属性的信息

select * from eav_attribute where attribute_id<=上面结果范围 and attribute_id>上面结果范围;取出customer的属性定义

看看magento中是怎样使用EAV模式的,还是拿customer
customer_entity用户的实体存放,当然里面也有是没有必用分开的属性,比如email,这是用户必须的,magento没有完全分开,可能也是考虑到速度
customer_entity_varchar
customer_entity_text
customer_entity_int
customer_entity_decimal
customer_entity_datetime
这几张表是实体对应的属性的值,属性值都有不同的类型,这样分开是有必要的
SELECT `cev`.*,`ea`.attribute_code FROM customer_entity_varchar AS
`cev` LEFT JOIN `eav_attribute` AS `ea` ON `ea`.attribute_id =
`cev`.attribute_id WHERE `cev`.entity_id = ‘2‘
;取出客户id为2的在customer_entity_varchar中的属性值

magento不仅提供了EAV模式,同时在数据库中完美支持了Flat表结构,flat和我们普通的表结构,一个产品对应一行数据,相对于EAV的多表
联查来说,单表单行数据的调用效率更高,magento默认是eav模式,可以在后台开启flat(就分类和产品用到)
catalog_product_flat_1
catalog_product_flat_2
后面数字代表store Id,刷新索引的时候会重新更新这些表数据

order表结构
sales_flat_order相关,表命名中带了flat,表示order不使用eav模式,我这么理解的
看这两张表
sales_flat_order_grid//后台grid列出来的相关数据,它把相应的放一起了,应该是为了方便调取,可是这样写的时候就的多了操作,考虑到读应该比写更频繁,这样应该也是可取的
sales_flat_order_item//同上,具体到某个order里面

sales_flat_quote相关表,在网站上点了产品放入购物车,但是没有下单,magento将这些产品暂时放入这些表中,下次用户登录到购物车会拿出来让客户继续,这个没得说。

magento的数据结构很灵活,上面写的也只是大概了解些,具体到实现,还是有很多东西的。

时间: 2024-10-29 04:06:24

magento 数据结构的相关文章

深入理解Magento - 第六章 - 高级Magento模型

我们讲过Magento有两种模型,简单模型和EAV(Entity Attribute Value)模型.上一章我们讲过所有的Magento模型都是继承自Mage_Core_Model_Abstract / Varien_Object.简单模型和EAV模型的区别在于资源模型(Model Resource).虽然所有的资源模型都最终继承“Mage_Core_Model_Resrouce_Abstract”,但是简单模型是直接继承“Mage_Core_Model_Mysql4_Abstract”,而E

Magento(社区版)自带模块解析以及在国内的使用建议二

11.CatalogIndex 跟商品相关的几种索引(价格.属性等等)的处理模块,商品是系统的核心组件,处理商品索引相关的模块自然也是核心模块,必须是开启状态. 12.CatalogInventory 核心模块之一的"库存"模块,管理者Magento的商品库存相关的功能. Magento的库存逻辑,主要通过两个字段来控制:库存数量(Qty)和库存状态(Stock Availability),理论上只有该商品库存数量大于0并且库存状态是In Stock时,这个商品才是前台真正可以售卖的.

深入理解Magento – 第六章 – 高级Magento模型(转)

深入理解Magento 作者:Alan Storm 翻译:Hailong Zhang 第六章 – 高级Magento模型 我们讲过Magento有两种模型,简单模型和EAV(Entity Attribute Value)模型.上一章我们讲过所有的Magento模型都是继承自Mage_Core_Model_Abstract / Varien_Object.简单模型和EAV模型的区别在于资源模型(Model Resource).虽然所有的资源模型都最终继承“Mage_Core_Model_Resro

Magento模型集合addFieldToFilter常用过滤条件

记录一下Magento模型集合Model Collection中addFieldToFilter()方法常用的过滤条件.以下参数也同样适用于产品实体的addAttributeToFilter()方法. //等于 Equals: eq $_products->addAttributeToFilter('status', array('eq' => 1)); //不等于 Not Equals - neq $_products->addAttributeToFilter('sku', arra

【数据结构】之散列链表(Java语言描述)

散列链表,在JDK中的API实现是 HashMap 类. 为什么HashMap被称为"散列链表"?这与HashMap的内部存储结构有关.下面将根据源码进行分析. 首先要说的是,HashMap中维护着的是一个数组: transient Node<K,V>[] table; ,数组中的每个元素都是一个 Node 对象.这里的Node是HashMap的一个内部类,代码如下: static class Node<K,V> implements Map.Entry<

旧题新做:从idy的视角看数据结构

“今天你不写总结……!!!” 额…… 还是讲我的吧.这些考试都是idy出的题. 20170121:DFS序. ST表.线段树练习 这是第一次考数据结构. Problem 1. setsum 1 second 给你一个长度为N 的整数序列,支持两种操作: • modity l r val 将区间[l,r] 中的所有数修改为val • query l r 询问区间[l,r] 所有数的和 分析:最简单的线段树,区间更改区间求和.但注意是更改,不是添改,sum与flag需同时覆盖. Problem 2.

数据结构Set和Map

一.数据结构 Set 集合的基本概念:集合是由一组无序且唯一(即不能重复)的项组成的.这个数据结构使用了与有限集合相同的数学概念,应用在计算机的数据结构中.  特点:key 和 value 相同,没有重复的 value.ES6 提供了数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. 1. 如何创建一个 Set const s = new Set([1, 2, 3]); 2.属性 console.log(s.size); // 3 3.Set 类的方法 --set.add(v

数据结构基本概念

什么是数据结构 "数据结构是数据对象,以及存在于该对象的实例和组成实例的数据元素之间的各种联系.这些联系可以通过定义相关的函数来给出"--Sartaj Sahni,<数据结构.算法与应用> "数据结构是ADT(抽象数据类型Abstract Data Type)的物理实现."--Clifford A.Shaffer,<数据结构与算法分析> "数据结构(data structture)是计算机中存储.组织数据的方式.通常情况下,经i想你

分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令

Redis数据类型 与Memcached仅支持简单的key-value结构的数据记录不同,Redis支持的数据类型要丰富得多,常用的数据类型主要有五种:String.List.Hash.Set和Sorted Set. Redis数据类型内存结构分析 Redis内部使用一个redisObject对象来表示所有的key和value.redisObject主要的信息包括数据类型(type).编码方式(encoding).数据指针(ptr).虚拟内存(vm)等.type代表一个value对象具体是何种数