| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2146 人关注过本帖
标题:现要 将学号为“95002”的学生的学号修改为“S001”?看看
只看楼主 加入收藏
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
 问题点数:0 回复次数:11 
现要 将学号为“95002”的学生的学号修改为“S001”?看看
表S
sno sname sssage sdept
95001 李勇 男 20 CS
95002 刘晨 女 19 IS
95003 王敏 女 18 MA
95004 张立 男 19 IS
表SC
sno cno grade
95001 1 92
95001 2 85
95001 3 88
95002 2 90
95002 3 80
现要 将学号为“95002”的学生的学号修改为“S001”?
/*create table SC
( sno char(9),
cno char (4),
grade smallint,
primary key (sno,cno),--主码由两个属性构成必须作为表级完整性进行定义
foreign key (sno) references s(sno),--表级完整性约束条件,sno是外码,被参照表是S
foreign key (cno) references C(cno),--表级完整性约束条件,cno是外码,被参照表是C
);*/
/*create table S
(sno char(9)primary key,
sname char(20)unique,
ssex char(2),
sage smallint ,
sdept char(20)
);*、
要如何修改?有种方法是先把表S,SC的约束性条件先去了,在修改,还有一种是可以先增加一属性列,然后再修改
如何实现呢,我做了好多编都无法成功,大家给个意见
搜索更多相关主题的帖子: S001 95002 学号 李勇 刘晨 
2007-04-16 13:00
daidaidai
Rank: 1
等 级:新手上路
帖 子:71
专家分:0
注 册:2006-5-31
收藏
得分:0 
alter taavle sc
alter sno foreign key references s (sno)on delete cascade on update cascade
你试下,不知道可不可以?


2007-04-16 14:03
Kendy123456
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:62
帖 子:2720
专家分:0
注 册:2007-1-3
收藏
得分:0 
指定外键的级联

CREATE TABLE SC
(
sno char(9) FOREIGN KEY REFERENCES S(sno) ON DELETE Cascade ON Update Cascade,
cno char (4),
grade smallint
)

直接对S所做的Sno的修改 和 删除 都在表SC中自动完成

2007-04-16 16:43
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
得分:0 

谢谢各位了


做你自己! everything will go! lanfei_1234@
2007-04-16 22:48
xiyou419
Rank: 1
等 级:新手上路
威 望:2
帖 子:104
专家分:0
注 册:2007-3-18
收藏
得分:0 
insert into S values('s001','刘晨','女','19','IS')
update SC set sno='s001' where sno='95002'
delete S where sno='95002'
试试这个~~~~~~~~~~~~~

[此贴子已经被作者于2007-4-17 10:26:27编辑过]


道德往往可以弥补智慧的缺陷;但智慧永远不能填补道德的空白.
2007-04-16 22:50
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
得分:0 
但是这样不行的,名字定义唯一了

做你自己! everything will go! lanfei_1234@
2007-04-18 17:46
w5644266
Rank: 1
等 级:新手上路
帖 子:101
专家分:0
注 册:2007-4-4
收藏
得分:0 
看来,我真的是太菜了啊!
2007-04-20 07:56
trhuang
Rank: 1
等 级:新手上路
帖 子:126
专家分:0
注 册:2007-4-1
收藏
得分:0 

我也想在这提一个问题:
如果是楼主的题目,现在我要求选修两门课程的学生的信息!
用上GROUP BY 的话怎样做!

2007-04-21 13:05
mingwangxing
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2007-5-24
收藏
得分:0 
你试一下用事务,它可以同时改几个表,避免了因为执行有先后而造成数据不一致性而出错。
begin tran myTran
update 表S set sno='S001' where sno='95002'
update 表SC set sno='S001' where sno='95002'
commit tran myTran


2007-05-26 01:55
niitstar
Rank: 1
等 级:新手上路
威 望:1
帖 子:114
专家分:0
注 册:2007-4-3
收藏
得分:0 
支持楼上的说法,我以前也遇到过这个问题。。。。

随风而来,乘风而去...
2007-05-28 09:39
快速回复:现要 将学号为“95002”的学生的学号修改为“S001”?看看
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017684 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved