设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 1376|回复: 2
打印 上一主题 下一主题

[查询] [求助] 跪求大神帮优化一个查询语句,万分感激

[复制链接]
跳转到指定楼层
1#
发表于 2016-11-27 07:11:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
说明:代码用于ACCESS数据库,实际应用中《用户表》数据有近二十万行,《地址表》数据有近五万行。我自己写的SQL语句能实现预期目的,但实在是太慢了,慢到受不了的地步。跪求大神帮优化一下SQL查询代码:

《用户表》结构及几个示例数据:
用户号码用户地址
13543211234重庆市万州区太白路129号1单元7-2
13543211235重庆市万州区太白路129号附3号2单元5-2
13543211236万州区太白路95号4栋9-5
13543211237重庆市万州区白岩路135号附4号10-2

《地址表》结构及几个示例数据:
地址前缀小区规范化命名
重庆市万州区太白路129号太白路129号
万州区太白路95号太白路95号
重庆市万州区白岩路147号白岩路147号


需求1:示例数据《用户表》中13543211237对应的地址前半部分“重庆市万州区白岩路135号”在《地址表》中不存在,需查询出来后手工处理。
我的代码(求优化):
SELECT 用户表.用户地址 FROM 用户表 LEFT JOIN 地址表 ON 用户表.用户地址 like 地址表.地址前缀+'*' WHERE 地址表.地址前缀 is null;

需求2:示例数据《用户表》中前三个号码对应的地址前半部分均已收录在《地址表》中。需要查询提取用户号码及小区规范化命名:
我的代码(求优化):
SELECT 用户表.用户号码, 地址表.小区规范化命名 FROM 用户表 LEFT JOIN 地址表 ON 用户表.用户地址 like 地址表.地址前缀+'*' WHERE 地址表.地址前缀 is not null;

个人感觉影响效率最大的问题是like语句,还加上了不确定字符数的通配符。但除此之外一直想不到其他方法。跪求指导啊。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅

点击这里给我发消息

2#
发表于 2016-11-27 13:50:40 来自手机 | 只看该作者
like本身就慢,加上索引
来自: 微社区
3#
 楼主| 发表于 2016-11-27 16:22:14 | 只看该作者
tmtony老师,因为我是每个月处理一次数据,并且没办法要求别人按规范提供标准化的数据。每次做索引很恼火。麻烦请教一下有没有更好的方法实现上述效果?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-3 16:53 , Processed in 0.086133 second(s), 26 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表