Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,002

Переименовать столбец во временной таблице

24.03.2025, 16:48. Показов 1361. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

SQL Server Management studio v18.7.1

T-SQL
1
2
3
4
5
6
7
8
DROP TABLE IF EXISTS #myTempTable1;
CREATE TABLE #myTempTable1 ([Период] DATETIME);
EXEC ('INSERT INTO #myTempTable1 VALUES (CONVERT(DATETIME, ''2025-01-24 18:05:49.517'', 120));');
 
ALTER TABLE #myTempTable1 ADD [Период_] [int];
EXEC ('UPDATE #myTempTable1 SET [Период_] = YEAR([Период]) * 100 + MONTH([Период]);');
ALTER TABLE #myTempTable1 DROP COLUMN [Период];
EXEC sp_rename '#myTempTable1.[Период_]', '[Период]', 'COLUMN';
На последней строке выдает ошибку: Либо задан сомнительный параметр @objname, либо требуемый @objtype (COLUMN) является ошибочным..
Как правильно написать?

Кстати, в этих строках
T-SQL
1
2
EXEC ('INSERT INTO #myTempTable1 VALUES (CONVERT(DATETIME, ''2025-01-24 18:05:49.517'', 120));');
EXEC ('UPDATE #myTempTable1 SET [Период_] = YEAR([Период]) * 100 + MONTH([Период]);');
используется exec. Без него скрипт выдает ошибку.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.03.2025, 16:48
Ответы с готовыми решениями:

Как автоматически обновлять столбец второй таблицы если тот же столбец обновляется в первой таблице?
Есть первая таблица M_TAX_ORG и при обновлении столбца NAME_R, во второй таблице M_TAX_ORG_ADM_INFO так же должен поменяться столбец NAME_R...

Как обратиться к временной таблице видимой во время выполнения?
Имеется 2 процедуры В главной создана временная таблица - в подчиненной нужно читать из нее данные. Как обойти синтаксический...

Как пробежатся по каждой строке во временной таблице?
Добрый день уважаемые форумчане, есть такая проблема. В хранимой процедуре вначале создаётся временная таблица и заполняется. В ней...

4
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
24.03.2025, 17:20
вместо sp_rename по-новой добавь поле период, скопируй туда из период_ и дропни период_. sp_rename наверняка точно так и поступает, зато избавишься от мозгосушилки связанной скорее всего с отсутствием каких-то полномочий или настроек
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
25.03.2025, 07:49
T-SQL
1
EXEC tempdb..sp_rename '#myTempTable1.[Период_]', '[Период]', 'COLUMN';
1
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,002
25.03.2025, 08:35  [ТС]
Спасибо!

Добавлено через 10 минут
Цитата Сообщение от MConst Посмотреть сообщение
Кстати, в этих строках
T-SQL
1
2
EXEC ('INSERT INTO #myTempTable1 VALUES (CONVERT(DATETIME, ''2025-01-24 18:05:49.517'', 120));');
EXEC ('UPDATE #myTempTable1 SET [Период_] = YEAR([Период]) * 100 + MONTH([Период]);');
используется exec. Без него скрипт выдает ошибку.
Почему когда запускаешь как скрипт (не как процедуру) без exec, то ругается?

А вот при использовании GO не ругается. Но если есть локальные переменные, то GO их же стирает.
SQL
1
2
3
4
5
6
7
8
9
10
11
12
DROP TABLE IF EXISTS #myTempTable1;
CREATE TABLE #myTempTable1 ([Период] DATETIME);
GO
INSERT INTO #myTempTable1 VALUES (CONVERT(DATETIME, '2025-01-24 18:05:49.517', 120));
 
ALTER TABLE #myTempTable1 ADD [Период_] [INT];
GO
UPDATE #myTempTable1 SET [Период_] = YEAR([Период]) * 100 + MONTH([Период]);
 
ALTER TABLE #myTempTable1 DROP COLUMN [Период];
EXEC tempdb..sp_rename '#myTempTable1.[Период_]', '[Период]', 'COLUMN';
SELECT * FROM #myTempTable1;
Добавлено через 14 минут
Цитата Сообщение от invm Посмотреть сообщение
T-SQL
1
EXEC tempdb..sp_rename '#myTempTable1.[Период_]', '[Период]', 'COLUMN';
Так создает поле '[Период]'

Вернее надо так
SQL
1
EXEC tempdb..sp_rename '#myTempTable1.[Период_]', 'Период', 'COLUMN';
создает поле 'Период'

А если нужно указать квадратные скобки (поле имеет спецсимволы и/или пробел), то как правильно написать?
0
1302 / 356 / 97
Регистрация: 14.10.2022
Сообщений: 1,084
25.03.2025, 09:05
Цитата Сообщение от MConst Посмотреть сообщение
А если нужно указать квадратные скобки (поле имеет спецсимволы и/или пробел), то как правильно написать?
Предварительно обработайте значение функцией Quotename()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.03.2025, 09:05
Помогаю со студенческими работами здесь

Есть смысл хранить одну переменную во временной таблице?
Есть база данных в которой будут хранится заказы. Номер заказ будет формироваться дата поступления + Номер заказа сегодняшнего дня. ...

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

Не могу переименовать столбец
Здравствуйте ALTER TABLE #__jshopping_categories CHANGE name_ru-RU name_ru-RU_new TEXT выдает ошибку #1064 - You have an error in...

Переименовать столбец таблицы БД MS Access через C#
Здравствуйте, не могу переименовать столбец таблицы, как только уже не пробовал, всё пишет: Варианты: 1.commP.CommandText =...

Как переименовать поле в таблице при помощи SQL запроса в Access
наппример в InterBase это выглядит так: ALTER TABLE tab_name ALTER COLUMN old_name TO new_nameа какой запрос надо написать для Access?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru