Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Копирование структуры таблицы, создание точной копии открытой таблицы 
V
    Опции темы
Pakshin A. S.
  Дата 15.6.2011, 16:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 5056
Регистрация: 16.2.2003

Репутация: 2
Всего: 61



Имеется некая таблица произвольной структуры. Необходимо скопировать данные из открытой таблицы в новую таблицу. Проблем с копированием естественно нет, но надо создать новую таблицу - полную копию текущей. Как можно узнать структуру таблицы, чтобы записать правильные типы полей в Create Table? Может есть встроенный механизм копирования таблицы?

На входе имеется только один TDataSet с открытой таблицей, где есть все поля и данные.

Тип используемой БД - MSSQL.

Добавлено через 11 минут и 33 секунды
Как вариант: пробежаться по Fields открытого DataSet и сгенерить запрос.  Где взять таблицу соответствия типа TFieldType и типов данных полей в MSSQL?

Это сообщение отредактировал(а) Pakshin A. S. - 15.6.2011, 16:13
PM   Вверх
Vas
Дата 15.6.2011, 17:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



Цитата(Pakshin A. S. @  15.6.2011,  16:11 Найти цитируемый пост)
Где взять таблицу соответствия типа TFieldType и типов данных полей в MSSQL?

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

Мне кажется еще проще использовать INFORMATION_SCHEMA (INFORMATION_SCHEMA.COLUMNS, INFORMATION_SCHEMA.TABLES и т.д.) или системные ХП (sp_colums, sp_tables ...). Они выдадут ту же информацию, но не в всей кучей сразу, а только то, что попросишь.



--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
Pakshin A. S.
Дата 15.6.2011, 17:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 5056
Регистрация: 16.2.2003

Репутация: 2
Всего: 61



INFORMATION_SCHEMA - отличная штука! Удобно юзать... буду пробовать. smile

Это сообщение отредактировал(а) Pakshin A. S. - 15.6.2011, 17:31
PM   Вверх
Данкинг
Дата 15.6.2011, 18:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



А в SQL-сервер нет оператора вроде фоксового copy structure ?


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
Akella
Дата 16.6.2011, 15:37 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Код

create table sometablename like some_other_table_name
create table sometablename as (select * from some_other_table_name)


Цитата

I believe 'SELECT * into new_table from table1' will copy both structure and data as well.

PM MAIL   Вверх
Данкинг
Дата 16.6.2011, 15:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



Цитата(Akella @  16.6.2011,  16:37 Найти цитируемый пост)
I believe 'SELECT * into new_table from table1' will copy both structure and data as well.

Так если с данными скопировать - то понятное дело.

Добавлено через 35 секунд
А:
Цитата(Pakshin A. S. @  15.6.2011,  17:11 Найти цитируемый пост)
Необходимо скопировать данные из открытой таблицы в новую таблицу. Проблем с копированием естественно нет, но надо создать новую таблицу - полную копию текущей.

Ну, тогда понятно. smile 



--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
DimW
Дата 17.6.2011, 10:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

Репутация: 5
Всего: 44



Цитата(Данкинг @  16.6.2011,  15:44 Найти цитируемый пост)
Так если с данными скопировать - то понятное дело.


без данных:
Код

create table sometablename as (select * from some_other_table_name where 1=0)



PM MAIL ICQ   Вверх
Pakshin A. S.
Дата 17.6.2011, 16:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 5056
Регистрация: 16.2.2003

Репутация: 2
Всего: 61



Спасибо за варианты решения проблемы!
PM   Вверх
Данкинг
Дата 17.6.2011, 19:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



Цитата(DimW @  17.6.2011,  11:52 Найти цитируемый пост)
where 1=0

Логично. smile Я помню, несколько лет назад у нас один товарищ подобным образом копировал таблицы на фоксе:
Код

set filter to dele() &&ставим фильтр на помеченные записи, которых нет
copy to NEW && копируем в новую таблицу записи по фильтру

 smile 


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
DimW
Дата 4.8.2011, 15:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

Репутация: 5
Всего: 44



Цитата(Данкинг @  17.6.2011,  19:13 Найти цитируемый пост)
Логично. 

Если логично, тогда к чему эта тупка в виде десятка постов выше?!...  
PM MAIL ICQ   Вверх
Данкинг
Дата 6.8.2011, 19:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



Цитата(DimW @  4.8.2011,  16:59 Найти цитируемый пост)
Если логично, тогда к чему эта тупка в виде десятка постов выше?!...   

Ты от меня конкретного ответа ожидаешь или это просто мысли вслух? smile 

Это сообщение отредактировал(а) Данкинг - 6.8.2011, 19:43


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.1710 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.