17,377
社区成员
发帖
与我相关
我的任务
分享
--1.为什么在Oracle中使用alter column修改数据类型报错?怎么样解决?
修改字段的语法:alter table tablename modify (column datatype [default value][null/not null],….);
--2.问题一:如果如上述所诉,char类型和varchar数据类型大小不一致吗?
char和varchar两种数据类型可以兼容。之后所有报错,是因为长度大小不一致。 长度改小肯定报错。
--3.问题二:清楚修改的字段的值使用update语句,但是我刚创建的表,表中并没有数据,应该清除什么字段呢?
--操作步骤如下:
--(1)先备份原表
create table course2_bak as select * from course2;
--(2)清空原表数据
truncate table course2;
--(3)修改原表字段
alter table course2 modify column sname varchar2(14);
--(4)还原数据
insert into course2 select * from course2_bak;
commit;
--4.第 1 行出现错误: ORA-00947: 没有足够的值
course2表总共4个字段,你才给3个字段赋值,肯定报错啊。