Magento常用SQL语句实用篇

2,181次阅读
没有评论

共计 5200 个字符,预计需要花费 13 分钟才能阅读完成。

如果网站更换域名或base_url网址后,导致本地测试打不开网站,可以执行以下语句设为默认值{{base_url}}
//网站默认URL
1 UPDATE `core_config_data` SET `value` = ‘{{base_url}}’ WHERE `path`=’web/unsecure/base_url’;

//网站安全URL
1 UPDATE `core_config_data` SET `value` = ‘{{base_url}}’ WHERE `path`=’web/secure/base_url’;

以下所有命令仅供参考,不同版本,不同时间,可能数据略有不同,慎用!

1. 导出导入 Magento 所有分类和产品
分类和产品是存放在以 catalog 开头的所有表中,对这组表进行导出导入即可实现此功能。
导入分类产品的 SQL 文件前注意:
在首行加入:
1 SET FOREIGN_KEY_CHECKS=0;

在末行加入:
1 SET FOREIGN_KEY_CHECKS=1;

原因是 Magento 使用 Innodb 存储引擎。

2. 批量修改分类的 Display Settings ——> Is Anchor 值为 No
1 UPDATE `catalog_category_entity_int` set value=0 WHERE value=1 AND attribute_id=120;

3. 批量处理所有 exclude 状态的图片
1 UPDATE `catalog_product_entity_media_gallery_value` SET disabled=0 WHERE disabled=1;

4. 批量调整所有产品的价格 ( 参考命令在 1.3 下通过 )
1 UPDATE `catalog_product_entity_decimal` SET value=round(value*1.45) WHERE attribute_id=99;

执行完后,需要到缓存管理里刷新:Layered Navigation Indices ,即可同步数据库里的关联表。

5. 清空邮件队列
1 TRUNCATE TABLE `newsletter_queue`;
1 TRUNCATE TABLE `newsletter_queue_link`;
1 TRUNCATE TABLE `newsletter_queue_store_link`;

注意:同时向上万顾客发邮件时,不要在后台查看邮件队列,不然服务器压力会很大,待邮件发完之后,记着清空邮件队列,这样在后台进入邮件队列就不会大量消耗服务器资源了。

6. Magento 转移站后,经常会出现下面这个提示,运行一下下面的SQL命令即可恢复正常。
错误提示:

Notice: Undefined index: 0 app/code/core/Mage/Core/Model/Mysql4/Config.php on line 92
SET FOREIGN_KEY_CHECKS=0;

1 update `core_store` set store_id = 0 where code=’admin’;
1 update `core_store_group` set group_id = 0 where name=’Default’;
1 update `core_website` set website_id = 0 where code=’admin’;
1 update `customer_group` set customer_group_id = 0 where customer_group_code=’NOT LOGGED IN’;
1 SET FOREIGN_KEY_CHECKS=1;

不过要明白,这个错误是使用了第三方数据库备份工具导致的,Magento 自带的备份功能是不会出现这个错误的。

7. 根据产品的 SKU 批量将产品自定义选项设为非必填:
1 UPDATE `catalog_product_option` SET is_require=0 WHERE product_id IN (SELECT entity_id FROM `catalog_product_entity` WHERE sku LIKE ‘SKU %’);

8. 关闭/开启 所有缺货产品
1 SET FOREIGN_KEY_CHECKS=0;
1 UPDATE `catalog_product_entity_int` SET value=2 WHERE attribute_id=80 and entity_id IN (SELECT product_id FROM `cataloginventory_stock_status` WHERE stock_status=0);
1 SET FOREIGN_KEY_CHECKS=1;

其它说明:value=2 为关闭,1为开启,attribute_id 对应不同版本的产品禁用项,最后执行完命令需要重建分类索引。

9. 取消所有问题邮件订阅
1 UPDATE `newsletter_subscriber` SET subscriber_status=3 WHERE subscriber_id IN (SELECT subscriber_id FROM `newsletter_problem`);

10. 清除产品与分类的描述与 Meta
重置所有产品short description
1 UPDATE `catalog_product_entity_text` SET value=’Short Description’ WHERE attribute_id=506;

清除所有产品Meta
1 UPDATE `catalog_product_entity_text` SET value=” WHERE attribute_id=97 OR attribute_id=104;
2 UPDATE `catalog_product_entity_varchar` SET value=” WHERE attribute_id=103 OR attribute_id=105;

清除所有产品URL
1 UPDATE `catalog_product_entity_varchar` SET value=” WHERE attribute_id=481;

清除所有分类描述:
1 UPDATE `catalog_category_entity_text` SET value=” WHERE attribute_id=112 OR attribute_id=115 OR attribute_id=116;

清除所有分类URL
1 UPDATE `catalog_category_entity_varchar` SET value=” WHERE attribute_id=479;

11. Magento 数据库清理
安全模式:清理日常数据库的无用记录
1 TRUNCATE TABLE `log_visitor`;
2 TRUNCATE TABLE `log_visitor_info`;
3 TRUNCATE TABLE `log_url`;
4 TRUNCATE TABLE `log_url_info`;
5 干净模式:清理数据库的无用记录
1 TRUNCATE `log_visitor` ;
2 TRUNCATE `log_url_info` ;
3 TRUNCATE `log_visitor_info` ;
4 TRUNCATE `dataflow_batch_import` ;
5 TRUNCATE `log_url` ;
6 TRUNCATE `report_event` ;
7 TRUNCATE `log_visitor_online` ;

备注:如果是转移网站,URL 重写表 core_url_rewrite 也可清空,转完站重建 URL 即可。

12. 批量修改 SKU、Meta、Name 等字段里的部份词
1 UPDATE `catalog_product_entity` SET sku=replace(sku,’oldskuw’,’newskuw’) WHERE sku LIKE ‘%oldskuw%’;
2 UPDATE `catalog_product_entity_text` SET value=replace(value,’oldmetaw’,’newmetaw’) WHERE value LIKE ‘%oldmetaw%’;
3 UPDATE `catalog_product_entity_varchar` SET value=replace(value,’oldnamew’,’newnamew’) WHERE value LIKE ‘%oldnamew%’;

13. 清站相关提示
能在后台清理的就在后台清理,直接对数据库操作有造成网站出错的可能性。其他辅助命令如下:
清除订单命令:
01 TRUNCATE `sales_flat_invoice`;
02 TRUNCATE `sales_flat_invoice_grid`;
03 TRUNCATE `sales_flat_invoice_item`;
04 TRUNCATE `sales_flat_order`;
05 TRUNCATE `sales_flat_order_address`;
06 TRUNCATE `sales_flat_order_grid`;
07 TRUNCATE `sales_flat_order_item`;
08 TRUNCATE `sales_flat_order_payment`;
09 TRUNCATE `sales_flat_order_status_history`;
10 TRUNCATE `sales_flat_quote`;
11 TRUNCATE `sales_flat_quote_address`;
12 TRUNCATE `sales_flat_quote_address_item`;
13 TRUNCATE `sales_flat_quote_item`;
14 TRUNCATE `sales_flat_quote_item_option`;
15 TRUNCATE `sales_flat_quote_payment`;
16 TRUNCATE `sales_flat_quote_shipping_rate`;
17 清除其它日志:
1 TRUNCATE `log_url_info`;
2 TRUNCATE `log_visitor_info`;
3 TRUNCATE `log_url`;
4 TRUNCATE `log_visitor`;
5 TRUNCATE `core_url_rewrite`;
6 TRUNCATE `report_event`;
7 TRUNCATE `report_viewed_product_index`;

14. 重置 Magento 所有 ID 统计数(如订单编码、发票编码等)
1 TRUNCATE `eav_entity_store`;
2 ALTER TABLE `eav_entity_store` AUTO_INCREMENT=1;

15. 批量调整指定产品的价格
1 create table xytmptb SELECT entity_id,value FROM `catalog_product_entity_varchar` WHERE (value LIKE ‘%Boot%’ OR value LIKE ‘%Shoes%’) AND attribute_id=60;
2 UPDATE `catalog_product_entity_decimal` SET value=value+10 WHERE entity_id IN (SELECT entity_id FROM `xytmptb`) AND attribute_id=64;
3 drop table xytmptb;

最后别忘了重建价格索引!

16. 分类与产品的反向开关
1 UPDATE `catalog_category_entity_int` SET value=if(value=0,1,0) WHERE attribute_id=119;
2 UPDATE `catalog_product_entity_int` SET value=if(value=1,2,1) WHERE attribute_id=273;

运行一下,开的关了,关的开了,再运一下反之,最后别忘了重建索引!

17. 批量禁用产品 —— 数据库操作
1 CREATE TABLE XYTMPTB SELECT entity_id,value FROM `catalog_product_entity_varchar` WHERE value LIKE ‘affliction%’ AND attribute_id=96;
2 UPDATE `catalog_product_entity_int` SET value=1 WHERE attribute_id=273 AND entity_id IN (SELECT entity_id FROM `XYTMPTB`);
3 DROP TABLE XYTMPTB;

别忘了重建索引!

18. 账户之间转移订单
1 UPDATE `sales_order` SET `customer_id`=newuserid WHERE `customer_id`=olduserid ;

正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
刘润2024年年度演讲,思维导图

刘润2024年年度演讲,思维导图

年底了,大佬们都开始演讲和总结了,今天下午刘润大哥也结束了本年度的演讲。刘润大哥看问题还是很深刻的,他的一些观...
SPC控制图——3σ方式

SPC控制图——3σ方式

上文中讲到SPC控制图的两种错误与解决办法,其解决办法就是调整上控制限与下控制限之间的距离,使其达到最优,而3...
为什么BOM可以撑起一个完美的生产计划

为什么BOM可以撑起一个完美的生产计划

教课书上对于技术资料的定义应该是比较严格的,一般都是指按照一定标准和格式成文的资料,包括BOM、图纸、工艺资料...
焊接工艺中容易忽略的13个问题,但SQE不能忽视!

焊接工艺中容易忽略的13个问题,但SQE不能忽视!

在焊接过程中,有许多需要注意的事项,一旦疏忽,有可能铸成大错。那么对于SQE来说,如果审核焊接工艺过程,这些要...
质量管理方法:如何消除质量失误

质量管理方法:如何消除质量失误

在生产过程中,负责质量管理工作的人员经常会遇到这样那样的问题,如工作中人为失误太多,怎样才能减少?面对客户投诉...
最新文章
Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

https://github.com/Free-TV/IPTV 项目简介 Free TV 是一个精心维护的开源...
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: