如何在SQL中用ALTER TABLE语句修改表中的列名?

补充一下~我做的是清华大学出版社的《数据库技术与应用实践教程》实验三第11题:使用Transact-SQL语句ALTERTABLE修改student_info表中的“姓名... 补充一下~我做的是清华大学出版社的《数据库技术与应用实践教程》

实验三第11题:使用Transact-SQL语句ALTER TABLE修改student_info表中的“姓名”列,使其列名为“学生姓名”,数据类型为varchar(10),非空。

按照题目的意思应该是可以用ALTER TABLE修改列名的呀!?
展开
 我来答
传奇勇者
2010-10-31 · TA获得超过747个赞
知道大有可为答主
回答量:1706
采纳率:75%
帮助的人:812万
展开全部
应该是
sp_rename '表名.原列名', '新列名'
标点符号也不能错,另外有约束列不能修改

补充:SQL 提供了sp_rename改名,ALTER TABLE可以修改、增加、删除列属性,但不能更改列名,除非是删除这个列,重新建一个列,这样的话数据就会丢失。这个题目的逻辑有问题。
百度网友fc3a7c2
2010-10-31 · TA获得超过897个赞
知道小有建树答主
回答量:275
采纳率:0%
帮助的人:206万
展开全部
实在不行,可以先添加"学生姓名"列,再删除"性名"列
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
QQ2k5
2010-10-30 · TA获得超过438个赞
知道小有建树答主
回答量:911
采纳率:25%
帮助的人:260万
展开全部
EXEC sp_rename 'tablename', 'newcol', 'oldcol'
表名 新列名 原列名

Alter不能修改列名
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
pwor85
2010-11-02 · TA获得超过329个赞
知道小有建树答主
回答量:586
采纳率:0%
帮助的人:401万
展开全部
ALTER TABLE SHELL MODIFY (年度 integer DEFAULT 2004);
请参考
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jyl_19
2010-10-31 · TA获得超过1002个赞
知道小有建树答主
回答量:708
采纳率:0%
帮助的人:1051万
展开全部
alter table student_info add “学生姓名”varchar(10);
update student_info set “学生姓名”='姓名';
alter table student_info drop column“姓名”;
思维定式啊,题目没说只能用一个语句。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式