热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql多表关联查询,增加了排序速度慢??

这些是表的结构:CREATETABLE`rs_emp`(`EmpSysID`varchar(36)NOTNULL,`EmpNo`varchar(20)NOTNULL,`EmpName`varchar(50)NOTNULLDEFAULT'',`EmpSexSysID`varchar(36)DEFAULTNULL,`CardTypeSysID`varchar(36)DEFAULTNULL,`RateSysID`varchar(3
mysql

这些是表的结构:
CREATE TABLE rs_emp (
EmpSysID varchar(36) NOT NULL,
EmpNo varchar(20) NOT NULL,
EmpName varchar(50) NOT NULL DEFAULT '',
EmpSexSysID varchar(36) DEFAULT NULL,
CardTypeSysID varchar(36) DEFAULT NULL,
RateSysID varchar(36) DEFAULT NULL,
JobSysID varchar(36) DEFAULT NULL,
DepartSysID varchar(36) NOT NULL,
StatusSysID varchar(36) DEFAULT NULL,
EmpEngName varchar(50) DEFAULT NULL,
EmpHireDate datetime DEFAULT NULL,
EmpPositiveDate datetime DEFAULT NULL,
EmpLeaveDate datetime DEFAULT NULL,
EmpLeaveReason varchar(255) DEFAULT NULL,
EmpStatusID tinyint(4) DEFAULT NULL,
EmpMemo varchar(200) DEFAULT NULL,
CertTypeSysID varchar(36) DEFAULT NULL,
EmpCertNo varchar(50) DEFAULT NULL,
EmpBirthDate varchar(50) DEFAULT NULL,
CountrySysID varchar(36) DEFAULT NULL,
NationSysID varchar(36) DEFAULT NULL,
EduSysID varchar(36) DEFAULT NULL,
EmpGdSchool varchar(200) DEFAULT NULL,
PolitySysID varchar(36) DEFAULT NULL,
EmpLanguageAbility varchar(200) DEFAULT NULL,
EmpMarrySysID varchar(36) DEFAULT NULL,
EmpZipNo varchar(50) DEFAULT NULL,
EmpPhoneNo varchar(50) DEFAULT NULL,
NativeSysID varchar(36) DEFAULT NULL,
EmpAddress varchar(200) DEFAULT NULL,
EmpEmail varchar(200) DEFAULT NULL,
EmpFamilyInfo varchar(200) DEFAULT NULL,
EmpBiography mediumtext,
AllowDelete bit(1) DEFAULT b'1',
EmpLeaveStatus bit(1) DEFAULT b'0',
IsAttend char(1) DEFAULT NULL,
OtherCardNo varchar(10) DEFAULT NULL,
CardFingerNo bigint(10) DEFAULT NULL,
PRIMARY KEY (EmpSysID),
UNIQUE KEY AK_RS_Emp (EmpNo),
KEY AK_RS_Emp2 (EmpSysID),
KEY AK_RS_Emp3 (EmpName),
KEY AK_RS_Emp6 (RateSysID),
KEY AK_RS_Emp7 (StatusSysID),
KEY AK_RS_Emp8 (CountrySysID),
KEY AK_RS_Emp9 (CertTypeSysID),
KEY AK_RS_Emp10 (EduSysID),
KEY AK_RS_Emp11 (PolitySysID),
KEY AK_RS_Emp12 (NationSysID),
KEY AK_RS_Emp23 (EmpSysID,EmpNo),
KEY AK_RS_Emp33 (EmpLeaveStatus),
KEY AK_RS_Emp22 (EmpSysID,EmpName)
) ENGINE=MyISAM DEFAULT CHARSET=gbk

CREATE TABLE rs_depart (
DepartSysID varchar(36) NOT NULL,
DepartPrcID varchar(100) NOT NULL,
DepartID varchar(12) NOT NULL,
DepartName varchar(50) NOT NULL,
DepartUpSysId varchar(36) DEFAULT NULL,
DepartMemo varchar(200) DEFAULT NULL,
PRIMARY KEY (DepartSysID),
UNIQUE KEY AK_RS_Depart (DepartID) USING BTREE
) ENGINE=MyISAM DEFAULT CHARSET=gbk

CREATE TABLE rs_classcerttype (
CertTypeSysID varchar(36) NOT NULL,
CertTypeNo varchar(20) NOT NULL,
CertTypeName varchar(50) NOT NULL,
PRIMARY KEY (CertTypeSysID),
UNIQUE KEY AK_RS_ClassCertType (CertTypeNo)
) ENGINE=MyISAM DEFAULT CHARSET=gbk

CREATE TABLE rs_classcountry (
CountrySysID varchar(36) NOT NULL,
CountryNo varchar(20) NOT NULL,
CountryName varchar(50) NOT NULL,
PRIMARY KEY (CountrySysID),
UNIQUE KEY AK_RS_ClassCountry (CountryNo)
) ENGINE=MyISAM DEFAULT CHARSET=gbk
跟rs_classcountry类似结构的表还有几张

最后创建视图,为这几张表的查询结果,视图:
CREATE ALGORITHM=UNDEFINED DEFINER=root@% SQL SECURITY DEFINER VIEW vrs_emp AS select a.EmpSysID AS EmpSysID,a.EmpNo AS EmpNo,a.EmpName AS EmpName,a.CardFingerNo AS CardFingerNo,a.EmpSexSysID AS EmpSexSysID,a.CardTypeSysID AS CardTypeSysID,a.RateSysID AS RateSysID,a.JobSysID AS JobSysID,a.DepartSysID AS DepartSysID,a.StatusSysID AS StatusSysID,a.EmpEngName AS EmpEngName,a.EmpHireDate AS EmpHireDate,a.EmpPositiveDate AS EmpPositiveDate,a.EmpLeaveDate AS EmpLeaveDate,a.EmpLeaveReason AS EmpLeaveReason,a.EmpStatusID AS EmpStatusID,a.EmpMemo AS EmpMemo,a.CertTypeSysID AS CertTypeSysID,a.EmpCertNo AS EmpCertNo,a.EmpBirthDate AS EmpBirthDate,a.CountrySysID AS CountrySysID,a.NationSysID AS NationSysID,a.EduSysID AS EduSysID,a.EmpGdSchool AS EmpGdSchool,a.PolitySysID AS PolitySysID,a.EmpLanguageAbility AS EmpLanguageAbility,a.EmpMarrySysID AS EmpMarrySysID,a.EmpZipNo AS EmpZipNo,a.EmpPhoneNo AS EmpPhoneNo,a.NativeSysID AS NativeSysID,a.EmpAddress AS EmpAddress,a.EmpEmail AS EmpEmail,a.EmpFamilyInfo AS EmpFamilyInfo,a.EmpBiography AS EmpBiography,a.AllowDelete AS AllowDelete,a.EmpLeaveStatus AS EmpLeaveStatus,a.IsAttend AS IsAttend,a.OtherCardNo AS OtherCardNo,(to_days(now()) - to_days(a.EmpPositiveDate)) AS EmpPositiveDay,floor(((to_days(curdate()) - to_days(a.EmpBirthDate)) / 365)) AS EmpAge,b.DepartID AS DepartID,b.DepartName AS DepartName,c.StatusNo AS StatusNo,c.StatusName AS StatusName,d.RateNo AS RateNo,d.RateName AS RateName,e.PolityNo AS PolityNo,e.PolityName AS PolityName,f.NativeNo AS NativeNo,f.NativeName AS NativeName,g.NationNo AS NationNo,g.NationName AS NationName,h.JobNo AS JobNo,h.JobName AS JobName,i.EduNo AS EduNo,i.EduName AS EduName,j.CountryNo AS CountryNo,j.CountryName AS CountryName,k.CertTypeNo AS CertTypeNo,k.CertTypeName AS CertTypeName,m.EmpSexID AS EmpSexID,m.EmpSexName AS EmpSexName,n.EmpStatusName AS EmpStatusName,o.EmpMarryID AS EmpMarryID,o.EmpMarryName AS EmpMarryName,p.CardPhysicsNo10 AS CardPhysicsNo10,p.CardPhysicsNo8 AS CardPhysicsNo8,p.CardSectorNo AS CardSectorNo,p.CardStatusID AS CardStatusID,p.CardStatusDate AS CardStatusDate,p.CardPWD AS CardPWD,p.CardStartDate AS CardStartDate,p.CardEndDate AS CardEndDate,p.CardUseDate AS CardUseDate,p.CardUseTimes AS CardUseTimes,p.RetirementFlag AS RetirementFlag,p.CardBTMoney AS CardBTMoney,p.FaDate AS FaDate,q.CardStatusName AS CardStatusName,r.EmpPhotoPath AS EmpPhotoPath from ((((((((((((((((rs_emp a join rs_depart b on((b.DepartSysID = a.DepartSysID))) left join rs_classstatus c on((c.StatusSysID = a.StatusSysID))) left join rs_classrate d on((d.RateSysID = a.RateSysID))) left join rs_classpolity e on((e.PolitySysID = a.PolitySysID))) left join rs_classnative f on((f.NativeSysID = a.NativeSysID))) left join rs_classnation g on((g.NationSysID = a.NationSysID))) left join rs_classjob h on((h.JobSysID = a.JobSysID))) left join rs_classeducation i on((i.EduSysID = a.EduSysID))) left join rs_classcountry j on((j.CountrySysID = a.CountrySysID))) left join rs_classcerttype k on((k.CertTypeSysID = a.CertTypeSysID))) left join vrs_empsex m on((m.EmpSexSysID = a.EmpSexSysID))) left join vrs_empstatus n on((n.EmpStatusID = a.EmpStatusID))) left join vrs_empmarrystatus o on((o.EmpMarrySysID = a.EmpMarrySysID))) left join rs_empcard p on((p.EmpSysID = a.EmpSysID))) left join vrs_empcardstatus q on((p.CardStatusID = q.CardStatusID))) left join rs_empphoto r on((a.EmpSysID = r.EmpSysID))) where (a.EmpLeaveStatus <> 1)

当我在mysql 用explain执行了一下 explain select * from vrs_emp where empsysid<>'' order by empno limit 0,30

出现
1 SIMPLE b system PRIMARY 1Using temporary; Using filesort

该如何优化??都有索引


推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
author-avatar
壮丁1987_536
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有