进入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语句,一般来说,它可以有更好的可扩展性和更佳的性能。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)