oracle查询效率

就是我现在有一个表是用户表(大约几百万条数据),用户表中有个唯一的用户的用户名。现在我要经常性(每天大约几万次)的从随机50个用户名(不一定注册的)中筛选出用户表中不存在... 就是我现在有一个表是用户表(大约几百万条数据),用户表中有个唯一的用户的用户名。现在我要经常性(每天大约几万次)的从随机50个用户名(不一定注册的)中筛选出用户表中不存在的用户名,有什么很好的办法。 展开
 我来答
hr_shenwei
2010-02-21 · TA获得超过178个赞
知道小有建树答主
回答量:222
采纳率:0%
帮助的人:265万
展开全部
如果在数据库层面无法解决的话,

就只好在应用层面解决了。

把所有用户名存在一个集合中,缓存起来。在整个系统运行期间。

然后在比较的时候,在应用层读取缓存进行比较操作。不用查询数据库了。

一般对于经常用到的数据都是这样操作的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
loveyurui
2010-02-21 · TA获得超过6556个赞
知道大有可为答主
回答量:2892
采纳率:33%
帮助的人:981万
展开全部
使用exists可能要好些
可以每次将随机提取的用户名插入到临时表table中。
select user_name from table a where not exists(select user_name from user b where a.user_name=b.user_name);
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
湖光居士
2010-02-21 · TA获得超过212个赞
知道小有建树答主
回答量:193
采纳率:0%
帮助的人:190万
展开全部
对于唯一性的索引查询,几百万条数据对于oracle来说是小case,基本上是不需要优化的。如果此表更新操作也比较频繁,可以定期更新或重建一下唯一性索引。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tj_angela
2010-02-21 · TA获得超过7530个赞
知道大有可为答主
回答量:6797
采纳率:75%
帮助的人:2548万
展开全部
对于这种情况,直接not exists效率还是很差的
首先索引是必须的

select user from table_50 a
where not exists
( select 1
from (select user from table_100W
where in (select user from table_50)) b
where a.user=b.user)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式