Heim > Backend-Entwicklung > PHP-Tutorial > mysql 合并表的数据

mysql 合并表的数据

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-06 20:36:42
Original
1196 Leute haben es durchsucht

有2张表 每张表大概1500W的数据
表一字段:
id pid name....

表二字段:
id pid age....
现在要将表的数据合并了

id pid name age...

怎么样实现比较好

回复内容:

有2张表 每张表大概1500W的数据
表一字段:
id pid name....

表二字段:
id pid age....
现在要将表的数据合并了

id pid name age...

怎么样实现比较好

假设age这张表的pid是这样的:

<code>1  2 3 4 5 6 7 ...
</code>
Nach dem Login kopieren

然后name这张表的pid是这样的:

<code>1 3 5 6 ...
</code>
Nach dem Login kopieren

name.pid (foreign key references on age.pid)

我们可以尝试下面这条SQL语句:

<code>SELECT * FROM name RIGHT OUTER JOIN age ON name.pid = age.pid ;
</code>
Nach dem Login kopieren

写sql合并就行了, 不知道 两个表的 id 和pid相同不

还有合并的时候是在线上?还是线下?需要保证数据库还能对外提供服务么

如果只保留一个id,以保留t1表为例
insert into t3(id,pid,name,age) select t1.id,t1.pid,t1.name,t2.age from t1,t2 where t1.pid = t2.pid;

如果两个id都要保留
insert into t3(id1,id2,pid,name,age) select t1.id,t2.id,t1.pid,t1.name,t2.age from t1,t2 where t1.pid = t2.pid;

<code>insert into t3(pid,name,age) select t1.pid,t1.name,t2.age from t1 left join t2 on t1.pid = t2.pid
</code>
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
So ändern Sie MySQL in MySQL
Aus 1970-01-01 08:00:00
0
0
0
MySQL-Startfehler unter Centos
Aus 1970-01-01 08:00:00
0
0
0
MySQL stoppt den Prozess
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage