oracle查询效率
就是我现在有一个表是用户表(大约几百万条数据),用户表中有个唯一的用户的用户名。现在我要经常性(每天大约几万次)的从随机50个用户名(不一定注册的)中筛选出用户表中不存在...
就是我现在有一个表是用户表(大约几百万条数据),用户表中有个唯一的用户的用户名。现在我要经常性(每天大约几万次)的从随机50个用户名(不一定注册的)中筛选出用户表中不存在的用户名,有什么很好的办法。
展开
4个回答
展开全部
如果在数据库层面无法解决的话,
就只好在应用层面解决了。
把所有用户名存在一个集合中,缓存起来。在整个系统运行期间。
然后在比较的时候,在应用层读取缓存进行比较操作。不用查询数据库了。
一般对于经常用到的数据都是这样操作的。
就只好在应用层面解决了。
把所有用户名存在一个集合中,缓存起来。在整个系统运行期间。
然后在比较的时候,在应用层读取缓存进行比较操作。不用查询数据库了。
一般对于经常用到的数据都是这样操作的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
今至电子科技有限公司
2024-08-23 广告
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整...
点击进入详情页
本回答由今至电子科技有限公司提供
展开全部
使用exists可能要好些
可以每次将随机提取的用户名插入到临时表table中。
select user_name from table a where not exists(select user_name from user b where a.user_name=b.user_name);
可以每次将随机提取的用户名插入到临时表table中。
select user_name from table a where not exists(select user_name from user b where a.user_name=b.user_name);
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
对于唯一性的索引查询,几百万条数据对于oracle来说是小case,基本上是不需要优化的。如果此表更新操作也比较频繁,可以定期更新或重建一下唯一性索引。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
对于这种情况,直接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)
首先索引是必须的
可
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)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询