时间:2021-07-01 10:21:17 帮助过:58人阅读
select b.name TableName,a.name IndexName from sys.sysindexes a right join sys.sysobjects b on a.id=b.id where b.xtype=‘U‘ and a.name is not null --删除IX 索引 declare @tableName varchar(max),@indexName varchar(max) declare index_cursor cursor for select b.name TableName,a.name IndexName from sys.sysindexes a right join sys.sysobjects b on a.id=b.id where b.xtype=‘U‘ and a.name is not null open index_cursor fetch next from index_cursor into @tableName,@indexName while @@FETCH_STATUS = 0 begin exec (‘DROP INDEX [‘+@indexName+‘] ON [dbo].[‘+@tableName+‘]‘) fetch next from index_cursor into @tableName,@indexName end close index_cursor deallocate index_cursor select b.name TableName,a.name ColumnName,a.* from syscolumns a inner join sysobjects b on b.id=a.id and b.xtype=‘U‘ inner join systypes c on a.xtype=c.xtype and c.name=‘uniqueidentifier‘ --修改uniqueidentifier的类型为nvarchar(max) declare @tableName varchar(max),@columnName varchar(max) declare change_type_cursor cursor for select b.name TableName,a.name ColumnName from syscolumns a inner join sysobjects b on b.id=a.id and b.xtype=‘U‘ inner join systypes c on a.xtype=c.xtype and c.name=‘uniqueidentifier‘ open change_type_cursor fetch next from change_type_cursor into @tableName,@columnName while @@FETCH_STATUS =0 begin exec (‘ALTER TABLE [dbo].[‘+@tableName+‘] ALTER COLUMN [‘+@columnName+‘] nvarchar(max) NOT NULL‘) fetch next from change_type_cursor into @tableName,@columnName end close change_type_cursor deallocate change_type_cursor
记录sql server 的批量删除主外键的sql语句
标签:记录 har lte open cat pen pes -- bsp