create table “新表” select * from “旧表” where 1 =2;
create table “新表” like “旧表”;上面两种方式的区别:使用第一条语句,备份的新表并没有旧表的primary key 、auto_increment等属性,需要重新对新表进行设置。
create table “新表” select * from “旧表”;
将oldtable中所有的内容都拷贝过来,同时也存在备份的新表不具备旧表 primary key、auto_increment等属性,需要对新表再次设置。
create table “新表” as select * from “旧表”;
select * into “新表” from “旧表”;
show engine innodb status;
show processlist;
show status like ‘%lock%;
show OPEN TABLES where In_use > 0; //这个语句记录当前锁表状态
show processlist;//查询表被锁进程
kill id;
分析相应SQL,给表加索引,常用字段加索引,表关联字段加索引。
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
SELECT * FROM v$lock; SELECT * FROM v$sqlarea; SELECT * FROM v$session; SELECT * FROM v$process ; SELECT * FROM v$locked_object; SELECT * FROM all_objects; SELECT * FROM v$session_wait;
select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id;
select b.username,b.sid,b.serial#,logon_time from v l o c k e d o b j e c t a , v locked_object a,v lockedobjecta,vsession b where a.session_id = b.sid order by b.logon_time;
SELECT sid, serial#, username, osuser FROM v$session;
SELECT s.sid, s.serial#, s.username, s.schemaname, s.osuser, s.process, s.machine,s.terminal, s.logon_time, l.type FROM v s e s s i o n s , v session s, v sessions,vlock l WHERE s.sid = l.sid AND s.username IS NOT NULL ORDER BY sid;
这个语句将查找到数据库中所有的DML语句产生的锁,还可以发现,任何DML语句其实产生了两个锁,一个是表锁,一个是行锁。
alter system kill session’210,11562’;
select spId from master…SysProcesses where db_Name(dbID) = ‘数据库名称’ and spId <> @@SpId and dbID <> 0;
exec ('Kill '+cast(@spid as varchar));
select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.dm_tran_locks where resource_type=‘OBJECT’;
spid 锁表进程
tableName 被锁表名
declare @spid int
Set @spid = 57 --锁表进程
declare @sql varchar(1000)
set @sql='kill '+cast(@spid as varchar)
exec(@sql)
create table students (
studentid int ,
studentname varchar(8),
age int,
constraint yy primary key(studentid)
);
alter table 表名 add constraint 主键名 primary key(主键字段);
ALTER TABLE 表名 DROP CONSTRAINT 主键名;
CREATE TABLE Personsfff(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT pk1_PersonID PRIMARY KEY (Id_P,LastName)
)
alter table 表名 add constraint 主键名 primary key(字段名1,字段名2……);
alter table 表名 drop constraint 主键名;
CREATE TABLE EIMS_EMERGENCY_ENTER (
SID VARCHAR(50) primary key NOT NULL,
ENTERID VARCHAR(50) NOT NULL,
DATA_TYPE VARCHAR(25) NOT NULL,
DEPT_NAME VARCHAR(100)
)
CREATE TABLE EIMS_EMERGENCY_ENTER (
SID VARCHAR(50) NOT NULL,
ENTERID VARCHAR(50) NOT NULL,
DATA_TYPE VARCHAR(25) NOT NULL,
DEPT_NAME VARCHAR(100),
primary key(SID,ENTERID)
)
ALTER TABLE <数据表名> ADD PRIMARY KEY(<列名>);
ALTER TABLE TABLE_NAME DROP PRIMARY KEY;
添加单列: ALTER TABLE 表名 ADD 列名 数据类型 添加多列: ALTER TABLE 表名 ADD 列名1 数据类型1,Add 列名2 数据类型2 另外,在添加字段时,还可以指定位数(日期类型除外)、是否为空、默认值 例如:ALTER TABLE t_test ADD type TINYINT(1) NOT NULL DEFAULT 0;
修改单列数据类型: ALTER TABLE 表名 MODIFY COLUMN 列名 数据类型 同时修改多列数据类型: ALTER TABLE 表名 MODIFYCOLUMN 列名 数据类型,MODIFY COLUMN 列名 数据类型 另外,在修改字段时,也可以指定位数、是否为空、默认值 ALTER TABLE t_test MODIFY COLUMN type TINYINT(2) DEFAULT 1;
在对字段进行修改时,注意下面几个问题:
删除单列: ALTER TABLE 表名 DROP COLUMN 列名 删除多列: ALTER TABLE 表名 DROP COLUMN 列名1,DROP COLUMN 列名2
ALTER TABLE 表名 ADD 列名1 数据类型1,MODIFY COLUMN 列名 数据类型,DROP COLUMN 列名1 (COLUMN 关键字可以省略)
添加单列: ALTER TABLE 表名 ADD 列名 数据类型 添加多列: ALTER TABLE 表名 ADD 列名1 数据类型1,列名2 数据类型2
修改单列数据类型: ALTER TABLE 表名 ALTER COLUMN 列名 数据类型 同时修改多列数据类型: 不支持
删除单列: ALTER TABLE 表名 DROP COLUMN 列名 删除多列: ALTER TABLE 表名 DROP COLUMN 列名1,列名2
不支持,每次只能进行一种操作.
添加单列: ALTER TABLE 表名 ADD 列名 数据类型 添加多列: ALTER TABLE 表名 ADD ( 列名1 数据类型1,列名2 数据类型2)
修改单列数据类型: ALTER TABLE 表名 MODIFY 列名 数据类型 同时修改多列数据类型: ALTER TABLE 表名 MODIFY ( 列名1 数据类型1,列名2 数据类型2)
删除单列: ALTER TABLE 表名 DROP COLUMN 列名 删除多列: ALTER TABLE 表名 DROP (列名1,列名2)
ALTER TABLE 表名 ADD ( 列名1 数据类型1,列名2 数据类型2) MODIFY ( 列名3 数据类型3,列名4 数据类型4)
select COUNT(*) from information_schema.tables WHERE table_name = ‘table_name’;
select COUNT(*) from information_schema.columns WHERE table_name = ‘table_name’ and column_name = ‘column_name’;
SELECT count(*) FROM USER_OBJECTS WHERE OBJECT_NAME = ‘table_name’;
SELECT COUNT(*) FROM USER_TAB_COLUMNS WHERE TABLE_NAME = ‘table_name’ and column_name = ‘column_name’;
select COUNT(*) from dbo.sysobjects WHERE name= ‘table_name’;
select COUNT(*) from syscolumns WHERE id=object_id(‘table_name’) and name= ‘column_name’;
–判断字段不存在则添加
if not exists(select * from sys.columns where name=‘字段名’ and [object_id]=object_id(N’表名’)) alter table 表名 add 字段名 nvarchar(255)
–判断字段存在则删除
if exists(select * from sys.columns where name=‘字段名’ and [object_id]=object_id(N’表名’)) alter table 表名 drop column 字段名