>

创建主键等常用操作总结,添加主键

- 编辑:澳门新葡亰平台游戏 -

创建主键等常用操作总结,添加主键

二. 针对表的多数操作

① 修改指定表的存储引擎,假设原本是MYISAM

alter table test_table engine=innodb;
  • 1

② 删除指定表的主键

alter table test_table drop primary key;
  • 1

这里有个情况需要指出,如果该主键列是自动增长(auto_increment)的,因为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;

重命名表:(Access 重命名表,请参考文章:在Access数据库中重命名表) 
sp_rename '表名', '新表名', 'OBJECT'

  Alter table tb change id id int(10);//删除自增长

一. 列常用操作

① 添加新的一列test_column,并将其作为主键,FIRST将其放在表中第一行,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字节长)

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

response.write rs("dida")'返回一个数值,0代表没有,1代表存在

  以上就是mysql添加删除主键的方法介绍。

删除Sql Server 中的日志,减小数据库文件大小 
dump transaction 数据库名 with no_log 
backup log 数据库名 with no_log 
dbcc shrinkdatabase(数据库名) 
exec sp_dboption '数据库名', 'autoshrink', 'true'

  Show create table tablename;//查看建立表“tablename”的sql语句

新增字段: 
ALTER TABLE [表名] ADD [字段名] NVARCHAR (50) NULL

  ) ENGINE=MyISAM DEFAULT CHARSET=utf8 |

alter table 表名 drop constraint 主键名
--添加主键
alter table 表名 add constraint 主键名 primary key(字段名1,字段名2……)
--添加非聚集索引的主键
alter table 表名 add constraint 主键名 primary key NONCLUSTERED(字段名1,字段名2……)

   Mysql的两种主键。Primary key 和not null auto_incriment在建立mysql表时,给一个字段添加了主键primary key 在insert数据时可以不用insert主键,mysql会自动添加0,但是在第二次insert时没有填写值mysql数据库还是默认添加0,会导致 有重复的主键,这是不可以的。所有在定义了primary key时,在insert数据时要给主键填写值。

\'检查表是否存在

  `BATCH_STATE` varchar(1) character set latin1 default NULL,

\'添加字段通用函数 
Sub AddColumn(TableName,ColumnName,ColumnType) 
Conn.Execute("Alter Table "&TableName&" Add "&ColumnName&" "&ColumnType&"") 
End Sub

  Alter table tb change id id int(10) not null auto_increment=1;

ALTER SCHEMA dbo TRANSFER prename.tablename;

  `BATCH_TIME` varchar(30) character set latin1 NOT NULL,

删除数据: 
DELETE FROM [表名] WHERE [字段名]>100

  Alter table tb add primary key(id);

--删除主键

  修改mysql的字符集:

新建表: 
create table [表名] 

[自动编号字段] int IDENTITY (1,1) PRIMARY KEY , 
[字段1] nVarChar(50) default '默认值' null , 
[字段2] ntext null , 
[字段3] datetime, 
[字段4] money null , 
[字段5] int default 0, 
[字段6] Decimal (12,4) default 0, 
[字段7] image null , 
)

  | maos_mail_batch | CREATE TABLE `maos_mail_batch` (

如果表2不存在,则用下面的语句会自动生成表2,字段的类型和表1一样: 
        select   字段1,字段2,..   INTO   表2   from   表1   where   ... 

  2、修改数据库和表的字符集

插入数据: 
INSERT INTO [表名] (字段1,字段2) VALUES (100,'51WINDOWS.NET')

  Alter table tb drop primary key;//删除主建

删除所有表:

  PRIMARY KEY (`ID`)  www.2cto.com  

set rs=conn.execute(sql)

  在建立mysql表时,给一个字段添加了主键not null auto_increment=1;

判断表的存在: 
select * from sysobjects where id = object_id(N'[dbo].[tablename]') and OBJECTPROPERTY(id, N'IsUserTable') = 1

  ALTER TABLE t1 CHANGE c1 c1 BLOB;  www.2cto.com  

修改字段: 
ALTER TABLE [表名] ALTER COLUMN [字段名] NVARCHAR (50) NULL

  这种方法能够实现此功能的原因是,当您转换到BLOB列或从BLOB列转换过来时,并没有发生转换。

\'更改字段通用函数 
Sub ModColumn(TableName,ColumnName,ColumnType) 
Conn.Execute("Alter Table "&TableName&" Alter Column "&ColumnName&" "&ColumnType&"") 
End Sub

  ALTER TABLE t1 CHANGE c1 c1 TEXT CHARACTER SET utf8;

更新数据: 
UPDATE [表名] SET [字段1] = 200,[字段2] = '51WINDOWS.NET' WHERE [字段三] = 'HAIWA'

 

删除表: 
Drop table [表名]

 

 

  这也是一个主键。时自增长的以1为开始。这个字段是可以不用填写值的,mysql数据库会自动给填写值,不会出现primary key的状况。

删除默认值 
ALTER TABLE [表名] DROP CONSTRAINT 默认值名

  在安装mysql5.0时可以设置好mysql的字符集,一般使用utf8的字符集

删除约束: 
ALTER TABLE [表名] DROP CONSTRAINT 约束名

  1、查看建立表“tablename”的sql语句

新建默认值 
ALTER TABLE [表名] ADD CONSTRAINT 默认值名 DEFAULT '51WINDOWS.NET' FOR [字段名]

  `BATCH_INTRODUCE` varchar(2000) character set latin1 default NULL,

修改表的前缀:

mysql添加删除主键 操作是非常基本的操作,下面就将教您mysql添加删除主键的方法,如果您是刚刚接触mysql数据库的新人,不妨一看。

DECLARE curItems CURSOR
FOR select [name] from sysobjects where xtype='U'
FOR READ ONLY
OPEN curItems
DECLARE @n  NVARCHAR(100),@m NVARCHAR(100)
FETCH FROM curItems INTO @n
WHILE @@FETCH_STATUS=0
BEGIN
 set @m=@n
    exec('Drop Table ' + @m)
FETCH NEXT FROM curItems INTO 
@n
END
CLOSE  curItems
DEALLOCATE  curItems

操作是非常基本的操作,下面就将教您mysql添加删除主键的方法,如果您是刚刚接触mysql数据库的新人,不妨一看。 修改...

sql="select count(*) as dida from sysobjects where id = object_id(N'[所有者].[表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1"

  alter table mailtable default character set utf8;//修改表的字符集

新建约束: 
ALTER TABLE [表名] ADD CONSTRAINT 约束名 CHECK ([约束字段] <= '2000-1-1')

  ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name;

删除字段: 
ALTER TABLE [表名] DROP COLUMN [字段名]

  警告:前面的操作转换了字符集之间的列类型。如果您有一列使用一种字符集(如latin1),但是存储的值实际上使用了其它的字符集(如utf8),这种情况不是您想要的。此时,您必须对这样的列进行以下操作。

某个表的结构 
select * from syscolumns where id = object_id(N'[dbo].[你的表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1

  先删除自增长在删除主键

如果表2已经存在,把表1中的记录加到表2中的语句: 
insert   into   表2   (字段1,字段2,...)   select   字段1,字段2,..   from   表2   where   ... 

  3、mysql的主键问题:

转载自:

  如果您想要把表默认的字符集和所有字符列(CHAR, VARCHAR, TEXT)改为新的字符集,应使用如下语句:

  alter database maildb default character set utf8;//修改数据库的字符集

  4、删除自增长的主键id

  `BATCH_SUM` int(11) default NULL,

作者 DouglasLau

  `ID` varchar(32) character set latin1 NOT NULL,

 

本文由数据库发布,转载请注明来源:创建主键等常用操作总结,添加主键