在同一个数据库一张表的修改,同步到另一张表

ww7433574 2011-06-21 12:26:55
比如说在 (员工信息表) 和 (员工工资表) 里面 原本张三的性别是 男 现在在(员工信息表)改成女后 ,(员工工资表)里面张三的性别还是男, 要怎么实现同步 ,谢谢 求代码 触发器没学 ,学了简单的存储过程
...全文
393 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
-晴天 2011-06-21
  • 打赏
  • 举报
回复
你可以在存储过程中先改员工信息表,接着立即再改员工资表.
也可以用触发器修改:
create table 员工信息表(id int,姓名 nvarchar(10),性别 nvarchar(1))
create table 员工工资表(id int,姓名 nvarchar(10),性别 nvarchar(1),工资 int)--不管其他列
insert into 员工信息表 select 1,'张三','男'
insert into 员工工资表 select 1,'张三','男',3000
go
create trigger setygxb
on 员工信息表
for update
as
update a set 性别=b.性别 from 员工工资表 a inner join inserted b on a.id=b.id
go
update 员工信息表 set 性别='女' where 姓名='张三'
select * from 员工工资表
/*
id 姓名 性别 工资
----------- ---------- ---- -----------
1 张三 女 3000

(1 行受影响)

*/
go
drop table 员工工资表,员工信息表
--小F-- 2011-06-21
  • 打赏
  • 举报
回复
如果有外键 还可以使用级联删除 这个直接去查查 

一般是可以使用触发器

create trigger my_tri on 员工信息表
for update
as
update a set 性别=b.性别 from 员工工资表 a inner join inserted b on a.id=b.id
go
update 员工信息表 set 性别='女' where 姓名='张三'
老潘 2011-06-21
  • 打赏
  • 举报
回复
1.触发器
2.存储过程里面同步更新
3.在 性别 列上建立外键,启用级联更新
cd731107 2011-06-21
  • 打赏
  • 举报
回复
(员工信息表) 和 (员工工资表)通过id关联
1.修改员工信息表中张三的性别
update 员工信息表 set 性别='女' where name='张三'
2.继续修改员工工资表中张三的性别
update 员工工资表 set 性别='女'
from 员工信息表 where 员工信息表.id=员工工资表.id
and 员工信息表.name='张三'

或者如一楼晴天老大那样弄个触发器,员工信息表更新后,
触发器自动更新员工工资表中的相应信息
Lyongt 2011-06-21
  • 打赏
  • 举报
回复
1.可以用触发器实现,楼上的已经回答了;
2.这个是表设计上的问题,如果系统还没有开发,可以改成员工信息表的员工ID和员工工资表的员工ID外键关联,去掉员工工资表中的冗余字段性别
DataUml Design 是面向开发人员使用的一个永久免费的软件,提高软件的开发效率和代码的规范度。它主要包括三大功能,数据模型、代码生成和UML建模,数据模型功能类似于PowerDesigner软件,代码生成类似于动软的代码生成器. DataUml Design是采用WPF开发的一款软件,该软件功能包括实体类建模、数据库设计、模型与数据库同步数据库与模型同步、代码生成、文档生成、数据库生成实体模型等功能。以往的软件修改模型之后还得修改数据结构,需要同步修改两个地方,而DataUml Design解决了该问题, 软件开发人员只需要修改模型结构或数据结构,然后利用软件的同步功能即可达到模型与数据结构的一致性。方便开发人员轻轻松松地管理自己的模型与数据库。 DataUml Design的自定义模板采用微软的4T技术,开发人员可以配置自己的代码模板。如实体层、数据访问层和UI层都可以用模板来配置,由模型一键生成代码,实现模型与代码的一致性。 DataUml Design支持数据的导入与导出,可以导出模型结构的文档,也支持其实数据导入生成数据模型(下一版本将实现)。 DataUml Design目前只支持MS Server和Oracle数据库、C#和Java语言,其它数据库和语言下一版本将实现。 DataUml Design功能特点 1)、模型设计 DataUml Desing数据建模采 用图形化设计,基于UML标准,遵循UML类图概念。模型中的类和数据库中的对应,类的成员分为字段、属性、事件等,类的属性对应数据中的字段。类的 属性成员的属性又包括数据中字段的所有属性。类与类的关联关系包括单向关联、双向关联、组合、聚合。关联关系与数据中的外键相对应。关联关系也具有属 性。 2)、模型和数据库同步 数据模型与数据库绑定,设计模型之后可以一键把模型提交到绑定的数据库中,如果数据库存在,则会更新数据结构,如果数据库中代不存在,则会创建一张新,用户不需要关心如何数据库类型,DataUml Design会帮你完成所有功能。 如果数据中增加了字段或修改了某个字段,需模型中需没有更改,只需把数据同步到模型即可,不需要开发人员对照数据结构来修改模型结构。 3)、代码生成 DataUml Desing采用代码模板来生成代码,软件开发人员可以根据自己的要求来设计代码模板。代码模板可以生成任务语言的代码。软件开发人员可以用代码模板获取到类的所有属性以及关联的类。

22,210

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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