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

php中文网
发布: 2016-06-06 09:45:33
原创
2594人浏览过
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)

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

阿里妈妈·创意中心 45
查看详情 阿里妈妈·创意中心

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

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

该如何优化??都有索引

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号