数据库字段匹配的问题

php中文网
发布: 2016-12-01 01:27:42
原创
1824人浏览过

现在有两个表(mysql
表1字段如下:省,市,手机号,姓名,其它字段
表2字段如下:省,市,手机号,其它字段

表1和表2的数据库都较大,日新增数据几百万行。
现在对表1和表2都进行了分表。
需求是:根据两表中的手机号匹配两表的数据。
问题是:
1、匹配的好的数据如何存储,是存储到第三个表,或者在表1加个字段,保持表2匹配的行的id。
2、如何查询未匹配的记录。

回复内容:

现在有两个表(mysql)
表1字段如下:省,市,手机号,姓名,其它字段
表2字段如下:省,市,手机号,其它字段

表1和表2的数据库都较大,日新增数据几百万行。
现在对表1和表2都进行了分表。
需求是:根据两表中的手机号匹配两表的数据。
问题是:
1、匹配的好的数据如何存储,是存储到第三个表,或者在表1加个字段,保持表2匹配的行的id。
2、如何查询未匹配的记录。

<code class="sql">create table zzz(
id int not null,
xx ...,
primary key(id)
) as (
select id, xx from table where ..
)</code>
登录后复制

http://dev.mysql.com/doc/refm...

未匹配的记录, 使用一张表作为左表关联另外一张表, 判断右表是否有 null 即可
例如

<code class="sql">select * from tb1
left join tb2 on tb1.mobi=tb2.mobi
where tb2.mobi is null</code>
登录后复制

这样的结果就是 tb1 中的所有没出现在 tb2 的记录

但是这样有另外一种情况 tb2 中如果有某个记录 tb1 不存在的就无法查出 tb1 的未匹配记录.
其实要查看两表是否全部匹配可以使用 full join 来进行匹配, 但是从你的这个数据量来看, 建议不要使用 full join , 就算用也不要查全部的.

关于 join 用法看这张图

数据库字段匹配的问题

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人

表的优化
1、手机号字段建索引

2、分表建议按手机号前几位来分表。

关于存储

建议表1表2分别加字段,存储另一表中的行。下次更新处理的时候可以跳过字段有值的部分处理。

未匹配的就是字段为空的。

另外

建议把更新直接放到记录的时候,往表1中加数据的时候查询是否在表2中存在。

查询的可以
select * from t1,t2 where t1.mobile = t2.mobile
查询出来了就可以创建新的了

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

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

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

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