Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как скопировать дерево из одной таблицы в другую? 
:(
    Опции темы
x404
Дата 26.11.2005, 00:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Доброго времени суток!
Помогите решить такую проблему. Имеется 2 таблицы, в которых надо хранить
древовидную структуру.
Первая - ТИПОВЫЕ СТАТЬИ, а вторая - РЕАЛЬНЫЕ СТАТЬИ.

---Структура таблиц:----
Article_t (ТИПОВЫЕ СТАТЬИ):
Id_Art_t,
ParentID_t,
IsFolder_t,
Name_t

Article (РЕАЛЬНЫЕ СТАТЬИ):
Id_Art,
ParentID,
IsFolder,
Name.

Поле ParentID_t указывает на родительский ID, т.е. на родителя.
Поле IsFolder_t определяет чем является данная запись - папкой, подпапкой или статьей. Глубина подпапок не ограничена(тут у меня и возникла проблема. smile )
Name_t - имя типовой папки/подпапки/статьи.

Проблема в следующем: как мне из таблицы типовых статей (Article_t) скопировать структуру дерева в таблицу с реальными статьями(Article)? Это надо для того, чтобы, когда заводилось новое предприятие, статьи сразу же заносисись из справочника(Article_t) в реальную таблицу(Article).
БД - Sybase 6.
Язык программирования - Delphi 6.
Используется ADO.
PM MAIL WWW ICQ Skype   Вверх
Cashey
Дата 26.11.2005, 14:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бессмертный
****


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

Репутация: нет
Всего: 60



В исходной таблице у тебя должно быть 4 поля ID записи, ID записи родителя (т.е. записи уровнем выше), номер вложенности, и поле хранящие ID записи первого уровня от которого и растет ветвь дерева. Тогда берешь записи, у которых номер вложенности меньше, и один ID первичной записи и все, если я правильно понял задачу.


--------------------
библия учит любить ближнего, а камасутра обучает как именно
PM Jabber   Вверх
LSD
Дата 26.11.2005, 16:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

Репутация: 24
Всего: 538



Не уверен что это сработает в Sybase, но попробуй так:
Вначале выполняешь:
Код
INSERT INTO article (id_art, parentid, isfolder, name)
SELECT id_art_t , parentid_t, isfolder_t, name_t FROM new_sales article_t
WHERE parentid_t is null

затем
Код
INSERT INTO article (id_art, parentid, isfolder, name)
SELECT id_art_t , parentid_t, isfolder_t, name_t FROM new_sales article_t
WHERE parentid_t is (SELECT id_art FROM article)

до тех пор пока количество вставленных строк не станет 0.

Или отключить на время FOREIGN KEY, выполнить
Код
INSERT INTO article (id_art, parentid, isfolder, name)
SELECT id_art_t , parentid_t, isfolder_t, name_t FROM new_sales article_t

а затем снова его включить.

Это сообщение отредактировал(а) LSD - 27.11.2005, 01:20


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
x404
Дата 27.11.2005, 01:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Я уже чуток все по другому за сегодня сделал: отказался я от справочника, но добавил еще одно поле - "ЗАМОРОЗКА". т.е. у меня для всех предприятий теперь будут присутствовать одни и теже статьи, а вот за работоспособность каждой конкретной статьи будет отвечать эта самая "заморозка",т.е. если статья заморожена, то ее для данного предприятия и нет. Спасибо тем кто откликнулся. Задачка не из простых все таки. А вот насчет номера вложенности в случае копирования статьи это, как мне кажется, абсолютно верно!Это и есть та самая зацепка, которой мне не хватало!!
PM MAIL WWW ICQ Skype   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


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

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


 




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


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

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