Как изменить несколько столбцов одновременно в SQL Server - PullRequest
114 голосов
/ 12 августа 2010

Мне нужно ALTER типы данных нескольких столбцов в таблице.

Для одного столбца хорошо работает следующее:

ALTER TABLE tblcommodityOHLC
ALTER COLUMN
    CC_CommodityContractID NUMERIC(18,0) 

Но как мне изменить несколькостолбцы в одном утверждении?Следующее не работает:

ALTER TABLE tblcommodityOHLC
ALTER COLUMN
    CC_CommodityContractID NUMERIC(18,0), 
    CM_CommodityID NUMERIC(18,0)

Ответы [ 13 ]

113 голосов
/ 12 августа 2010

Это невозможно.Вам нужно будет сделать это один за другим.

Вы можете создать временную таблицу с измененными столбцами, скопировать данные, удалить исходную таблицу и переименовать временную таблицу в исходное имя.

18 голосов
/ 05 июля 2013

Выполнение нескольких действий ALTER COLUMN внутри одного оператора ALTER TABLE невозможно.

Смотрите здесь синтаксис ALTER TABLE:
http://msdn.microsoft.com/en-US/library/ms190273.aspx

Вы можете сделать несколько ADD или несколькоУБРАТЬ КОЛОННУ, но только одну АЛЬТЕРНУЮ КОЛОННУ.

8 голосов
/ 24 января 2015

Следующее решение не является одним оператором для изменения нескольких столбцов, но да, оно упрощает жизнь:

  1. Генерирует сценарий CREATE таблицы.

  2. Заменить CREATE TABLE на ALTER TABLE [TableName] ALTER COLUMN для первой строки

  3. Удалить ненужные столбцы из списка.

  4. Измените типы данных столбцов по своему усмотрению.

  5. Выполните Найти и заменить… следующим образом:

    1. Найти:NULL,
    2. Заменить на: NULL; ALTER TABLE [TableName] ALTER COLUMN
    3. Нажать Заменить кнопку .
  6. Запустить скрипт.

Надеюсь, это сэкономит много времени :))

7 голосов
/ 11 августа 2016

Как уже отвечали другие, вам нужно несколько операторов ALTER TABLE.Попробуйте:

ALTER TABLE tblcommodityOHLC alter column CC_CommodityContractID NUMERIC(18,0);
ALTER TABLE tblcommodityOHLC alter column CM_CommodityID NUMERIC(18,0);

и т. Д.

2 голосов
/ 26 июля 2017

Как уже говорили многие другие, вам нужно будет использовать несколько операторов ALTER COLUMN, по одному для каждого столбца, который вы хотите изменить.

Если вы хотите изменить все или несколько столбцов в вашей таблице на один и тот же тип данных (например, расширить поле VARCHAR с 50 до 100 символов), вы можете автоматически сгенерировать все операторы, используя запрос ниже. Этот метод также полезен, если вы хотите заменить один и тот же символ в нескольких полях (например, удалить \ t из всех столбцов).

SELECT
     TABLE_CATALOG
    ,TABLE_SCHEMA
    ,TABLE_NAME
    ,COLUMN_NAME
    ,'ALTER TABLE ['+TABLE_SCHEMA+'].['+TABLE_NAME+'] ALTER COLUMN ['+COLUMN_NAME+'] VARCHAR(300)' as 'code'
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'your_table' AND TABLE_SCHEMA = 'your_schema'

Это создает оператор ALTER TABLE для каждого столбца для вас.

1 голос
/ 12 августа 2010

Если вы вносите изменения в Management Studio и генерируете сценарии, она создает новую таблицу и вставляет в нее старые данные с измененными типами данных. Вот небольшой пример изменения двух типов данных столбца

/*
   12 August 201008:30:39
   User: 
   Server: CLPPRGRTEL01\TELSQLEXPRESS
   Database: Tracker_3
   Application: 
*/

/* To prevent any potential data loss issues, you should review this script in detail before running it outside the context of the database designer.*/
BEGIN TRANSACTION
SET QUOTED_IDENTIFIER ON
SET ARITHABORT ON
SET NUMERIC_ROUNDABORT OFF
SET CONCAT_NULL_YIELDS_NULL ON
SET ANSI_NULLS ON
SET ANSI_PADDING ON
SET ANSI_WARNINGS ON
COMMIT
BEGIN TRANSACTION
GO
ALTER TABLE dbo.tblDiary
    DROP CONSTRAINT FK_tblDiary_tblDiary_events
GO
ALTER TABLE dbo.tblDiary_events SET (LOCK_ESCALATION = TABLE)
GO
COMMIT
BEGIN TRANSACTION
GO
CREATE TABLE dbo.Tmp_tblDiary
    (
    Diary_ID int NOT NULL IDENTITY (1, 1),
    Date date NOT NULL,
    Diary_event_type_ID int NOT NULL,
    Notes varchar(MAX) NULL,
    Expected_call_volumes real NULL,
    Expected_duration real NULL,
    Skill_affected smallint NULL
    )  ON T3_Data_2
     TEXTIMAGE_ON T3_Data_2
GO
ALTER TABLE dbo.Tmp_tblDiary SET (LOCK_ESCALATION = TABLE)
GO
SET IDENTITY_INSERT dbo.Tmp_tblDiary ON
GO
IF EXISTS(SELECT * FROM dbo.tblDiary)
     EXEC('INSERT INTO dbo.Tmp_tblDiary (Diary_ID, Date, Diary_event_type_ID, Notes, Expected_call_volumes, Expected_duration, Skill_affected)
        SELECT Diary_ID, Date, Diary_event_type_ID, CONVERT(varchar(MAX), Notes), Expected_call_volumes, Expected_duration, CONVERT(smallint, Skill_affected) FROM dbo.tblDiary WITH (HOLDLOCK TABLOCKX)')
GO
SET IDENTITY_INSERT dbo.Tmp_tblDiary OFF
GO
DROP TABLE dbo.tblDiary
GO
EXECUTE sp_rename N'dbo.Tmp_tblDiary', N'tblDiary', 'OBJECT' 
GO
ALTER TABLE dbo.tblDiary ADD CONSTRAINT
    PK_tblDiary PRIMARY KEY NONCLUSTERED 
    (
    Diary_ID
    ) WITH( PAD_INDEX = OFF, FILLFACTOR = 86, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON T3_Data_2

GO
CREATE UNIQUE CLUSTERED INDEX tblDiary_ID ON dbo.tblDiary
    (
    Diary_ID
    ) WITH( PAD_INDEX = OFF, FILLFACTOR = 86, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON T3_Data_2
GO
CREATE NONCLUSTERED INDEX tblDiary_date ON dbo.tblDiary
    (
    Date
    ) WITH( PAD_INDEX = OFF, FILLFACTOR = 86, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON T3_Data_2
GO
ALTER TABLE dbo.tblDiary WITH NOCHECK ADD CONSTRAINT
    FK_tblDiary_tblDiary_events FOREIGN KEY
    (
    Diary_event_type_ID
    ) REFERENCES dbo.tblDiary_events
    (
    Diary_event_ID
    ) ON UPDATE  CASCADE 
     ON DELETE  CASCADE 

GO
COMMIT
0 голосов
/ 25 января 2019

Если вы не хотите сами писать все и менять все столбцы на один и тот же тип данных, это может упростить задачу:

select 'alter table tblcommodityOHLC alter column '+name+ 'NUMERIC(18,0);'
from syscolumns where id = object_id('tblcommodityOHLC ')

Вы можете скопировать и вставить вывод как запрос

0 голосов
/ 02 апреля 2018

Благодаря примеру кода Эвана я смог изменить его и сделать его более конкретным для таблиц, начиная с конкретных имен столбцов И обрабатывая особенности для ограничений.Я запустил этот код, а затем скопировал столбец [CODE] и выполнил его без проблем.

USE [Table_Name]
GO
SELECT
     TABLE_CATALOG
    ,TABLE_SCHEMA
    ,TABLE_NAME
    ,COLUMN_NAME
    ,DATA_TYPE
    ,'ALTER TABLE ['+TABLE_SCHEMA+'].['+TABLE_NAME+'] DROP CONSTRAINT [DEFAULT_'+TABLE_NAME+'_'+COLUMN_NAME+']; 
ALTER TABLE  ['+TABLE_SCHEMA+'].['+TABLE_NAME+'] ALTER COLUMN ['+COLUMN_NAME+'] datetime2 (7) NOT NULL 
ALTER TABLE  ['+TABLE_SCHEMA+'].['+TABLE_NAME+'] ADD CONSTRAINT [DEFAULT_'+TABLE_NAME+'_'+COLUMN_NAME+'] DEFAULT (''3/6/2018 6:47:23 PM'') FOR ['+COLUMN_NAME+']; 
GO' AS '[CODE]'
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME LIKE 'form_%' AND TABLE_SCHEMA = 'dbo'
 AND (COLUMN_NAME = 'FormInserted' OR COLUMN_NAME = 'FormUpdated')
 AND DATA_TYPE = 'datetime'
0 голосов
/ 14 июля 2017

Если я правильно понял ваш вопрос, вы можете добавить несколько столбцов в таблицу, используя приведенный ниже запрос.

Запрос:

Alter table tablename add (column1 dataype, column2 datatype);
0 голосов
/ 08 мая 2017

Мы можем изменить несколько столбцов в одном запросе следующим образом:

ALTER TABLE `tblcommodityOHLC`
    CHANGE COLUMN `updated_on` `updated_on` DATETIME NULL DEFAULT NULL AFTER `updated_by`,
    CHANGE COLUMN `delivery_datetime` `delivery_datetime` DATETIME NULL DEFAULT CURRENT_TIMESTAMP AFTER `delivery_status`;

Просто введите запросы через запятую.

...