sql 表1中a字段内容要修改为表2中B字段的内容,语句怎么写

2024-11-05 07:33:06
推荐回答(4个)
回答(1):

select a.学生名,b.联系电话 from 表1 a inner join (select 学生ID,min(联系电话) as 联系电话 from 表2 group by 学生ID) b on a.学生ID=b.学生ID
回答者:lazy67 - 高级经理 七级 7-30 13:14
这个查出来是联系电话最小的那个 而不是第一个

如果利用ROWID机制的话对上面SQL进行一些改动:
SELECT A.学生名,B.联系电话 FROM 表1 A,表2 B
WHERE A.学生ID = B.学生ID AND B.ROWID IN (SELECT MIN(ROWID) FROM 表B GROUP BY ID)
我手边只有ORACLE 10G 测试成功
不知道是不是所有数据库都有ROWID机制

回答(2):

假设表1与表2是通过id这个字段关联的 那么 应该这样写
update 表1
set a=b
from 表2
wher 表2.id=表1.id

回答(3):

uddate 表1 set a = 表2.B

回答(4):

表2中B字段的值是唯一的么?表1中的a字段和表2中B字段数据一样多么? 你说的不清楚啊,没法给你写