Mysql增長主鍵或者更改表的列爲主鍵的sql語句

                                                                                                                      www.169it.comhtml

添加表字段sql

alter table table1 add transactor varchar(10) not Null;spa

alter table   table1 add id int unsigned not Null auto_increment primary keycode

修改某個表的字段類型及指定爲空或非空htm

alter table 表名稱 change 字段名稱 字段名稱 字段類型 [是否容許非空];索引

alter table 表名稱 modify 字段名稱 字段類型 [是否容許非空];ci

alter table 表名稱 modify 字段名稱 字段類型 [是否容許非空];rem

修改某個表的字段名稱及指定爲空或非空get

alter table 表名稱 change 字段原名稱 字段新名稱 字段類型 [是否容許非空cmd

刪除某一字段

ALTER TABLE mytable DROP 字段 名;

添加惟一鍵

ALTER TABLE `test2` ADD UNIQUE ( `userid`)

修改主鍵

ALTER TABLE `test2` DROP PRIMARY KEY ,ADD PRIMARY KEY ( `id` )

增長索引

ALTER TABLE `test2` ADD INDEX ( `id` )

ALTER TABLE `category ` MODIFY COLUMN `id`  int(11) NOT NULL AUTO_INCREMENT FIRST ,ADD PRIMARY KEY (`id`);

 

修改主鍵的sql語句塊以下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
declare  @defname  varchar (100)
declare  @cmd  varchar (500)
declare  @tablename  varchar (100)
declare  @keyname  varchar (100)
Set  @tablename= 'Temp1'
Set  @keyname= 'id'  --須要設置的key,分隔
select  @defname=  name
    FROM  sysobjects so 
    JOIN  sysconstraints sc
    ON  so.id = sc.constid
    WHERE  object_name(so.parent_obj) = @tablename
    and  xtype= 'PK'
if @defname  is  not  null
begin
select  @cmd= 'alter table ' + @tablename+  ' drop constraint ' + @defname
--print @cmd
    exec  (@cmd)
  end
else
  set  @defname= 'PK_' +@keyname
select  @cmd= 'alter table ' + @tablename+  ' ADD constraint ' + @defname + ' PRIMARY KEY CLUSTERED(' +@keyname+ ')'
    exec  (@cmd)

 

  如何取主鍵字段名稱及字段類型--獲得主鍵字段名

  1:

SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE

WHERE TABLE_NAME<>'dtproperties'

  2:

EXEC sp_pkeys @table_name='表名'

  3:

select o.name as 表名,c.name as 字段名,k.colid as 字段序號,k.keyno as 索引順序,t.name as 類型

from sysindexes i

join sysindexkeys k on i.id = k.id and i.indid = k.indid

join sysobjects o on i.id = o.id

join syscolumns c on i.id=c.id and k.colid = c.colid

join systypes t on c.xusertype=t.xusertype

where o.xtype = 'U' and o.name='要查詢的表名'

and exists(select 1 from sysobjects where xtype = 'PK' and parent_obj=i.id and name = i.name)

order by o.name,k.colid

 


本文來源:Mysql增長主鍵或者更改表的列爲主鍵的sql語句

相關文章
相關標籤/搜索