求sql语句,两个表之间的更新

fisher2008 2008-09-05 11:08:33
两个表 比如A表,和B表
A表
id name
1 a
2 b
B表
id name
1 a
2 bbb
3 c

请教 如何用最简单的语句,实现B表的数据更新到A表,自动判断(insert,update,或数据一样的不操作),即id为1的不更新,id为2的update,id为3的insert
...全文
307 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
子陌红尘 2008-09-05
  • 打赏
  • 举报
回复
那就从A中delete两个表的交集,然后再把B表不存在于A的记录(包括刚刚删除的)一并insert到A表。

delete A where exsists(select 1 from B where id=A.id)

insert into A select * from B where not exists(select 1 from A where ID=B.ID)
fisher2008 2008-09-05
  • 打赏
  • 举报
回复
不能truncate的,a表数据,有的是B表没有的
子陌红尘 2008-09-05
  • 打赏
  • 举报
回复
如果没有自增字段的话,你完全可以把A表的数据TRUNCATE掉,然后把B表的数据全部insert过来,省时省力......
fisher2008 2008-09-05
  • 打赏
  • 举报
回复
大哥,谢谢啊,还有一步啊
如果这个表有100个字段或更多,那我这句set和where很长,a表,b表的结构完全一样,如果不指定字段实现以下功能
update A set A.name=B.name from A,B where A.id=B.id and A.name!=B.name
子陌红尘 2008-09-05
  • 打赏
  • 举报
回复
1、

update A set A.name=B.name from A,B where A.id=B.id and A.name!=B.name

insert into A select * from B where not exists(select 1 from A where id=B.id)



2、跨服务器访问

--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go

--查询示例
select * from srv_lnk.数据库名.dbo.表名

--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名

--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
go

--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)


--导入示例
select * into 表 from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
fisher2008 2008-09-05
  • 打赏
  • 举报
回复
A表在服务器上,B表在个人笔记本上,表名是一样的,实际上程序实现的data sync
fisher2008 2008-09-05
  • 打赏
  • 举报
回复
1但id为1的不更新,能不能做到? 即关联,如果数据相同,不update
2还有update能否不指定字段,要默认所有的字段,a,b表结构完全一样,实际上几十个字段,一一指定太麻烦了了
hyrongg 2008-09-05
  • 打赏
  • 举报
回复
还不如直接把b表RENAME成A表算了。

看你要得到的就是B表的内容嘛。
天-笑 2008-09-05
  • 打赏
  • 举报
回复
被楼上的抢了,郁闷!
子陌红尘 2008-09-05
  • 打赏
  • 举报
回复
update A set A.name=B.name from A,B where A.id=B.id

insert into A select * from B where not exists(select 1 from A where id=B.id)
sp4 2008-09-05
  • 打赏
  • 举报
回复
这样的例子太多了,子陌红尘下手够快,呵呵
Crazy_Xia 2008-09-05
  • 打赏
  • 举报
回复
高人太多,没有发挥的余地。。。
内容概要:本文围绕“基于超局部模型与自抗扰ESO观测器的无模型预测电流控制改进策略”展开研究,提出一种结合超局部模型(ULM)与扩张状态观测器(ESO)的无模型预测电流控制(MFPCC)改进方法,旨在提升永磁同步电机(PMSM)电流环的动态响应性能与抗干扰能力。该策略利用超局部模型对系统行为进行局部逼近,避免依赖精确数学模型,同时引入自抗扰控制中的ESO实时观测并补偿系统内外部扰动,有效抑制参数摄动、负载变化及模型不确定性带来的影响。研究通过Simulink搭建完整的控制系统仿真模型,对传统MFPCC与所提改进策略进行对比分析,验证了新方法在电流跟踪精度、响应速度和鲁棒性方面的优越性。; 适合人群:具备电机控制、现代控制理论及Simulink仿真基础的电气工程、自动化及相关专业的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于高性能电机驱动系统中电流环控制器的设计与优化;②为无模型控制与自抗扰控制的融合应用提供技术参考;③支撑相关课题的仿真验证、论文复现与创新方法研究。; 阅读建议:建议读者结合Simulink仿真模型深入理解控制结构与参数整定过程,重点关注ESO的观测性能与扰动补偿机制,并可通过改变负载条件、参数偏差等工况进行鲁棒性测试,进一步掌握该改进策略的核心优势与适用边界。

34,876

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧