- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
首先,我知道我应该使用模型而不是直接处理数据库。话虽如此,有谁知道 Magento 是如何处理非全局产品属性的?
我在 core_website
中有 2 个网站: 管理员 (website_id = 0) 和主网站 (website_id =1)。我在core_store
也有两家店:管理员(store_id = 0)和默认商店 View (store_id = 0)。似乎产品(或类别?)属性是否在范围内是全局的存储在 catalog_eav_attribute
中。 . is_global
.值 0 对应于“商店 View ”的范围,值 1 对应于“全局”,而 2 对应于“网站”。到现在为止还挺好。
现在,如果我想获取商店特定属性的值,例如“名称”( eav_attribute
. attribute_id
= 71; eav_attribute
. backend_type
= 'varchar'; catalog_eav_attribute
. |104| . |104| 0)对于我所有的产品,你会认为我会做这样的事情:
SELECT *
FROM catalog_product_entity_varchar
WHERE attribute_id = 71
AND store_id = 1
is_global
的行中= 0。据我所知,数据库中存储的唯一属性
store_id
= 1 是“url_key”和“url_path”。那么 Magento 是如何存储这些值的呢? Magento 如何检索它们?
store_id
中吗? = 0 作为一种默认值,直到需要存储与该值不同的值?当需要存储与 admin 值不同的 store-specific 值时,magento 是否会使用
store_id
创建一个新行= 1(或任何 store_id)?
store_id
.
catalog_eav_attribute
首先是有问题的属性?如果它是非全局的,那么它可以首先使用
is_global
进行查询。 = 1,如果没有返回,则使用默认值
store_id
查询= 0?
store_id
= 0 和
store_id
= 1 并根据属性是否为全局以及 store_id = 1 是否存在值来选择正确的值?
最佳答案
你似乎已经想通了。至少你对事情的处理方式有一个很好的了解。
总结并确认您的怀疑:
所有的属性值都存储在 catalog_product_entity_*
哪里*
可以是论文中的任何一个:decimal, int, varchar, text, datetime
取决于属性类型( backend_type
)。
还有其他表格可以保存与层定价和图像相关的数据,但让我们暂时搁置。
属性表定义
每个表都有以下列:
value_id - just an increment id for the table
entity_type_id - the entity type id for the product (always the same)
attribute_id - reference to the attribute
store_id - reference to the store view
entity_id - reference to the product
value - actual value
entity_id
,
attribute_id
,
store_id
.这意味着对于一种产品和一种属性,您的商店 View 只能有一个值。
store_id = 0
意味着存储在那里的值是一个默认值。
store_id = 0
的值即使您有
store_id = 1
的值,也会被使用.
Mage::app()
创建了应用程序的实例):
$collection = Mage::getModel('catalog/product')->getCollection()
->addAttributeToFilter('name', 'some_name');
echo $collection->getSelect();
some_name
的产品列表。 .
SELECT
`e`.*,
IF(at_name.value_id > 0, at_name.value, at_name_default.value) AS `name`
FROM
`catalog_product_entity` AS `e`
INNER JOIN
`catalog_product_entity_varchar` AS `at_name_default`
ON (`at_name_default`.`entity_id` = `e`.`entity_id`) AND
(`at_name_default`.`attribute_id` = '96') AND
`at_name_default`.`store_id` = 0
LEFT JOIN
`catalog_product_entity_varchar` AS `at_name`
ON (`at_name`.`entity_id` = `e`.`entity_id`) AND
(`at_name`.`attribute_id` = '96') AND
(`at_name`.`store_id` = 1)
WHERE
(IF(at_name.value_id > 0, at_name.value, at_name_default.value) = 'some_name')
name
属性(在我的例子中为 96)是商店 View 范围属性(
is_global
= 0)Magento 与表
catalog_product_entity_varchar
连接两次(保存
name
的那个),一次用于当前商店 View ,一次用于 detault 商店 View (id = 0)。添加条件:
IF(at_name.value_id > 0, at_name.value, at_name_default.value)
$collection = Mage::getModel('catalog/product')->getCollection()
->addAttributeToFilter('weight', '1');
echo $collection->getSelect();
SELECT
`e`.*,
`at_weight`.`value` AS `weight`
FROM
`catalog_product_entity` AS `e`
INNER JOIN
`catalog_product_entity_decimal` AS `at_weight`
ON (`at_weight`.`entity_id` = `e`.`entity_id`) AND
(`at_weight`.`attribute_id` = '101') AND
(`at_weight`.`store_id` = 0)
WHERE
(at_weight.value = '1')
catalog_product_entity_decimal
对于商店 id = 0。
website
一切都像商店 View 范围一样发生,因为 Magento 在保存产品时为当前网站中的每个商店 View 在属性值表中创建一行。
status
在上面的例子中。
catalog_product_flat_{store_view_id_here}
.
Use in product listing
标记的属性被转换成列。
System->Configuration->Catalog->Frontend->Use Flat Catalog Product
打开/关闭此功能(或
Use Flat Catalog Category
)。
关于mysql - 如何在 Magento mysql 数据库中存储/查询商店/网站特定(或非全局)产品属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22024288/
我需要按不同类别过滤我网站上的产品。例如,如果您选择“DRINKS”类别,它将向我显示属于该类别的产品。 为了更好地解释自己。 我需要按类别过滤我网站的出版物 [产品],例如,在选择一个类别时说“饮料
我有 orders 集合,其中包含 products 集合。我将一些产品 ID 作为列表传递给该方法。我需要返回与任何匹配的产品列表input 列表中的 id。 我需要像这样使用 foreach 循环
我已经为临时分发进行存档好几个月了,但今天突然我无法这样做,因为“存档”菜单项已被禁用。我没有改变任何东西。我完成了该项目的配置设置,看起来没问题。 我的临时个人资料即将在 14 天后过期。这可能是问
我正在尝试找出产品和产品属性之间的关系。我有一个 product 表和一个 product_attributes 表。产品可以具有多种属性。我需要查询来查找具有一个特定属性和另一个属性之一的所有产品。
我正在使用 MySQL Workbench 创建 EER 图。 实现产品、类别和公司表之间关系的最佳方式是什么? 我正在考虑这种关系,但考虑到我想让公司的客户管理自己的产品/类别,这是最好的方式吗?如
我正在使用 itertools 包,并尝试在具有 900 个值的数组中创建 1、2 和 3 的所有可能组合,然后将其转换为 30 x 30 矩阵。我必须执行此操作的代码在下面并且工作正常。 for d
我有几个关于 Cartridge 启动器的问题: 我的产品不需要评级或发布日期。他们永远不会出售。一些产品是可下载的,因此“num_in_stock”不相关或本质上是无限制的。没有颜色选项,只有尺寸。
在 MySQL 中,存储产品价格(或一般货币)的首选列类型是什么?谷歌知道我经常使用 DECIMAL of FLOAT,但我想知道哪个更好。 我存储的价格范围是 0.01 到 25.00。当然更高的值
在软件开发过程中,尤其是在准备将新功能或修复后的版本上线之前,进行详尽的自测和上线前检查是至关重要的。以下是一个从多个维度综合考量的上线升级检查清单(Checklist),旨在帮助团队确保软件质量、稳
我正在创建一个闪购网站,并且我已经在主页和商店页面上根据日期范围显示产品。但我也想根据其他地方的日期范围显示产品,因此使用简码。 这是我的代码: function testt($meta_query)
可以在 WooCommerce 上批量创建产品吗?我正在使用 wp-cli Product 命令,但似乎我必须一个一个地创建。 'My product 1'), array('title'
我有一个带有数量和价格列的 excel 文件,我用它来为插件 WooCommerce Dynamic Pricing 创建必要的输出的定价规则。 我几乎想通了,但是 WooCommerce 进口商正在
我刚刚继承了一个woocommerce项目,我需要将主页更改为仅显示特定品牌。他们设置了 Product-Data => Attribute => pa_brand。 如果我打印 pa_brand 数
在插件中如何使用 wc_get_products() 获取产品。或者有其他方法可以做到吗? if ( in_array( 'woocommerce/woocommerce.php', apply_fi
我正在做一个无法从公司网络外部访问的内部网,他们希望在 Plone 中显示一些关于文件下载和最常查看的页面的不错的统计数据。 由于网络限制,我无法使用谷歌分析或任何类型的外部服务,那么是否有任何产品可
我正在就以下问题寻求建议: 保留哪些产品 key 属于哪个客户端的列表。例如,如果我的产品 key 为 8456-7894-4567-7894,则应该这样设计,以便将列表写入数据库而不是文件。 如何将
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
尝试将产品搜索栏添加到 Wordpress 管理栏后端,以进行 Woocommerce 产品搜索。它将位于后端管理菜单栏的顶部,这样无论您在后端的哪个位置,都可以搜索 woo 的产品。我很接近但在小绊
这让我抓狂.. 我正在尝试根据特定属性查询和输出 WooCommerce 产品。例如,我设置了一个名为 on 的属性,可能的值为 yes或 no . 我使用以下查询: $args = array(
我正在尝试从 Shopify 商店获取所有产品的 JSON。我一直在向 {STORE URL}/products.json 端点。但这最终只显示了商店提供的部分产品(很多,但不是全部)。当我将参数更改
我是一名优秀的程序员,十分优秀!