转载大器晚成篇相比康健的,创制主键等常用操作总计

转载大器晚成篇相比康健的,创制主键等常用操作总计

一. 列常用操作


增添新的一列test_column,并将其看作主键,FI中华VST将其放在表中首先行,auto_increement是全自动拉长

alter table test_table add column test_column int not null auto_increment FIRST add primary key(test_column);
  • 1

 

能够利用SQL语句“alter table ai3 add id0 int  auto_increment primary key
first;”来增多主键列。能够行使SQL语句“alter table ai4 modify id int
auto_increment primary key;”来更正主键列。

② 删除列

 

alter table test_table drop column test_column;
  • 1

③ 改良某一列的字段长度(比如本来是30字节改为50字节长卡塔尔(英语:State of Qatar)

alter table test_table modify column test_column varchar(50);
  • 1

④ 完全修改某一列(假诺原来列名是test1_column,类型是int)

alter table test_table change column test1_column test_column varchar(30);
  • 1


仅仅想重命名某一列(首先供给理解这一列的项目,假若原本是int且不为空,列名是error_name_column)

alter table test_table change column error_name_column test_column int not null;
  • 1

Oracle
扩大改过删除字段

二. 针对表的超过六分之三操作

① 更正钦赐表的蕴藏引擎,借使原来是MYISAM

alter table test_table engine=innodb;
  • 1

② 删除钦命表的主键

alter table test_table drop primary key;
  • 1

此处有个状态供给建议,借使该主键列是机关拉长(auto_increment卡塔尔(英语:State of Qatar)的,因为mysql供给机关增进列必需是索引,所以删除主键也就删除了主键索引,那是不符合mysql必要的,是心有余而力不足兑现的,会报错,必需先删除自动增进(通过校正列属性),后删除主键

③ 为钦命表增加主键

alter table test_table add primary key(test_column);
  • 1

④ 为钦赐表加多索引(普通索引),test_index是索引名

alter table test_table add index test_index(test_column);
  • 1

⑤ 删除内定表索引

alter table test_table drop index test_index;
  • 1

⑥ 重命名表

alter table test_table rename new_name_table;

 

 



 

 

比如想在三个意气风发度建好的表中增多一列,能够用诸如:

alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(20) not
null;

那条语句会向已有些表中参预新的一列,这一列在表的末梢一列地方。假诺我们希望增加在内定的一列,能够用:

alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(20) not
null after COLUMN_NAME;

专心,上面那么些命令的意思是说增多新列到某一列前面。借使想加多到第一列的话,能够用:

alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(20) not
null first;

增多字段的语法:alter table tablename add (column datatype [default
value][null/not null],….);

改良字段的语法:alter table tablename modify (column datatype [default
value][null/not null],….);

剔除字段的语法:alter table tablename drop (column卡塔尔(英语:State of Qatar);

增添、匡正、删除多列的话,用逗号隔断。

采用alter table 来扩张、删除和改革三个列的例证。

创制表构造:

create table test1

(id varchar2(20) not null);

充实一个字段:

alter table test1

add (name varchar2(30) default ‘无名氏’ not null);

选择三个SQL语句同期丰盛两个字段:

alter table test1

add (name varchar2(30) default ‘无名氏’ not null,

age integer default 22 not null,

has_money number(9,2)

);

改过叁个字段

alter table test1

modify (name varchar2(16) default ‘unknown’);

另:相比较正规的写法是:

— Add/modify columns

alter table TABLE_NAME rename column FIELD_NAME to NEW_FIELD_NAME;

去除二个字段

alter table test1

drop column name;

要求在意的是生龙活虎旦某一列中曾经存在值,借使您要改进的为比那几个值还要小的列宽那样将会现出三个不当。

诸如前边如若大家插入叁个值

insert into test1

values (’1′,’大家很爱您’卡塔尔国;

下一场曾改革列: alter table test1

modify (name varchar2(8));

将会拿走以下错误:

ERROR 位于第 2 行:

ORA-01441: 无法减小列长度, 因为一些值过大


高端用法:

重命名表

ALTER TABLEtable_nameRENAME TOnew_table_name;

改正列的称号

语法:

ALTER TABLE table_name RENAME COLUMN supplier_name to sname;

范例:

alter table s_dept rename column age to age1;

附:成立带主键的表>>

create table student (

studentid int primary key not null,

studentname varchar(8),

age int);

1、创造表的同期创造主键节制

(1)无命名

create table student (

studentid int primary key not null,

studentname varchar(8),

age int);

(2)有命名

create table students (

studentid int ,

studentname varchar(8),

age int,

constraint yy primary key(studentid));

2、删除表中原来就有的主键约束

(1)无命名

可用 SELECT * from user_cons_columns;

查找表中主键名称得student表中的主键名叫SYS_C002715

alter table student drop constraint SYS_C002715;

(2)有命名

alter table students drop constraint yy;

3、向表中加多主键约束

alter table student add constraint pk_student primary key(studentid);

admin

网站地图xml地图