dede5.6数据库升级5.7数据库,怎么升级啊

dede5.6数据库升级5.7数据库,怎么升级啊,第1张

进入mysql管理或后台SQL命令行工具,运行以下升级语句

alter table `#@__addoninfos` CHANGE `infotype`  `infotype` char(20)  NOT NULL    default '0'  COMMENT ''  AFTER `nativeplace`;
alter table `#@__addonshop` ADD `vocation` char(20)  NOT NULL    default '0'  COMMENT ''  AFTER `redirecturl`;
alter table `#@__addonshop` ADD `infotype` char(20)  NOT NULL    default '0'  COMMENT '' ;
alter table `#@__addonshop` ADD `uptime` int(11)  NOT NULL    default '0'  COMMENT '' ;
alter table `#@__archives` ADD `voteid` mediumint(8)  NOT NULL    COMMENT ''  AFTER `badpost`;
alter table `#@__homepageset` ADD `showmod` tinyint(2)  NOT NULL    default '1'  COMMENT ''  AFTER `position`;
alter table `#@__member_stow` CHANGE `type`  `type` varchar(10)    COMMENT ''  AFTER `addtime`;
CREATE TABLE `#@__purview` (
  `mid` mediumint(8) default '0',
  `typeid` smallint(5) default '0',
  `rank` smallint(6) default NULL,
  `pkey` varchar(30) character set latin1 NOT NULL,
  `pvalue` text NOT NULL,
  KEY `pkey` USING BTREE (`pkey`)
)ENGINE=MyISAM;
CREATE TABLE `#@__sphinx` (
  `countid` int(11) unsigned NOT NULL,
  `maxaid` int(11) unsigned NOT NULL,
  PRIMARY KEY  (`countid`)
)ENGINE=MyISAM;
alter table `#@__sys_enum` CHANGE `evalue`  `evalue` char(20)  NOT NULL    default '0'  COMMENT ''  AFTER `ename`;
alter table `#@__vote` ADD `isallow` tinyint(6)  NOT NULL    default '0'  COMMENT ''  AFTER `ismore`;
alter table `#@__vote` ADD `view` tinyint(6)  NOT NULL    default '0'  COMMENT '' ;
alter table `#@__vote` ADD `spec` int(20) unsigned  NOT NULL    default '0'  COMMENT '' ;
alter table `#@__vote` ADD `isenable` tinyint(6)  NOT NULL    default '0'  COMMENT '' ;
CREATE TABLE `#@__vote_member` (
  `id` mediumint(8) unsigned NOT NULL auto_increment,
  `voteid` int(10) unsigned NOT NULL default '0',
  `userid` varchar(50) NOT NULL default '',
  `uptime` int(10) unsigned NOT NULL default '0',
  PRIMARY KEY  (`id`)
)ENGINE=MyISAM;
alter table `#@__member` ADD `checkmail` smallint(6)  NOT NULL    default '-1'  COMMENT ''  AFTER `loginip`;
INSERT INTO `#@__sysconfig` VALUES('752','cfg_mysql_type','数据库类型(支持mysql和mysqli)','2','string','mysqli'),
('753','cfg_sphinx_article','是否启用文章全文检索功能(需配置sphinx服务器)','7','bool','N'),
('754','cfg_sphinx_host','Sphinx服务器主机地址','7','string','localhost'),
('756','cfg_sphinx_port','Sphinx服务器端口号','7','number','9312'),
(14, 'cfg_domain_cookie', '跨域共享cookie的域名(例如: dedecmscom)', 2, 'string', ''),
('757','cfg_memcache_enable','是否启用memcache缓存,如果为否(N),默认使用文件缓存',6,'bool','N'),
('758','cfg_memcache_mc_defa','默认memcache缓存服务器地址',6,'string','memcache://127001:11211/default127'),
('759','cfg_memcache_mc_oth','附加memcache缓存服务器地址',6,'string','');
UPDATE `#@__sysconfig` SET  `info` =  'Html编辑器(ckeditor,需要fck的用户可以去官网下载)', `value` =  'ckeditor' WHERE  `varname` =  'cfg_html_editor';

GROUP BY、DISTINCT、ORDERBY这几类子句比较类似,GROUP BY默认也是要进行ORDERBY排序的,笔者在本书中 把它们归为一类,优化的思路也是类似的。

可以考虑的优化方式如下。

1、尽量对较少的行进行排序。
2、如果连接了多张表,ORDERBY的列应该属于连接顺序的第一张表。
3、利用索引排序,如果不能利用索引排序,那么EXPLAIN查询语句将会看到有filesort。
4、GROUP BY、ORDERBY语句参考的列应该尽量在一个表中,如果不在同一个表中,那么可以考虑冗余一些列,或者合并表。
5、需要保证索引列和ORDERBY的列相同,且各列均按相同的方向进行排序。
6、增加sort_buffer_size。 sort_buffer_size是为每个排序线程分配的缓冲区的大小。增加该值可以加快ORDERBY或GROUP BY *** 作。但是,这是为每 个客户端分配的缓冲区,因此不要将全局变量设置为较大的值,因为每个需要排序的连接都会分配sort_buffer_size大小的内存。
7、增加read_rnd_buffer_size。 当按照排序后的顺序读取行时,通过该缓冲区读取行,从而避免搜索硬盘。将该变量设置为较大的值可以大大改进ORDER BY的性能。但是,这是为每个客户端分配的缓冲区,因此你不应将全局变量设置为较大的值。相反,只用为需要运行大查询 的客户端更改会话变量即可。

8、改变tmpdir变量指向基于内存的文件系统或其他更快的磁盘。 如果MySQL服务器正作为复制从服务器被使用,那么不应将“--tmpdir”设置为指向基于内存的文件系统的目录,或者当服务 器主机重启时将要被清空的目录。因为,对于复制从服务器,需要在机器重启时仍然保留一些临时文件,以便能够复制临时表 或执行LOADDATAINFILE *** 作。如果在服务器重启时丢失了临时文件目录下的文件,那么复制将会失败。

9、指定ORDERBY NULL。 默认情况下,MySQL将排序所有GROUP BY的查询,如果想要避免排序结果所产生的消耗,可以指定ORDERBY NULL。 例如:SELECT count() cnt, cluster_id FROM stat GROUP BY cluster_id ORDER BY NULL LIMIT 10; ·

10、优化GROUP BY WITHROLLUP。 GROUP BY WITHROLLUP可以方便地获得整体分组的聚合信息(superaggregation),但如果存在性能问题,可以考虑在应用层实现这个功能,这样往往会更高效,伸缩性也更佳。

11、使用非GROUP BY的列来代替GROUP BY的列。 比如,原来是“GROUP BYxx_name,yy_name”,如果GROUP BYxx_id可以得到一样的结果,那么使用GROUP BYxx_id也是可 行的。

12、可以考虑使用Sphinx等产品来优化GROUP BY语句,一般来说,它可以有更好的可扩展性和更佳的性能。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10634561.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存