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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Подогнать под 3НФ 
V
    Опции темы
zhenya1
Дата 8.12.2011, 22:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Здравтвуйте, есть такая проблемка:
У меня есть есть "БД" и сервер, который с ней и работает.
БД содержит 7 табличек с одинаковыми полями, но разными названиями.(см.ниже). На сервере я, в зависимости от выбраной таблички, скажем, посылаю запрос для заполнения всех её полей и т.д.
Но вся проблема в том, что они никак между собой не связаны, а код вроде как уже написан. Как можно сделать осмысленные связи между ними, чтобы я по прежнему мог работать с ними как раньше?!

Код

CREATE TABLE APP.RESPONSIBILITY (
DOCUMENTNAME VARCHAR(45),
 AGENCYNAME VARCHAR(65),
 CLIENTNAME VARCHAR(76) ,
PASPORTNUMBER INT,
 OBJECTNAME VARCHAR(65),
 SUMINSURED INT,
 INSURANCERISK VARCHAR(65),
 INSURANCEVZNOS INT, 
INSURANCETIMEACTIVITY DATE,
INSURANCETIMEACTIVITYFINAL DATE,
 DOCUMENTNUMBER INT NOT NULL,
CONFIRMDOCUMENT VARCHAR(65),
INSURANCEPAYMENT INT,
DATEPAYMENT DATE,
 PRIMARY KEY (DOCUMENTNUMBER )
);


Код

CREATE TABLE APP.CARGO (
DOCUMENTNAME VARCHAR(45),
 AGENCYNAME VARCHAR(65),
 CLIENTNAME VARCHAR(76) ,
PASPORTNUMBER INT,
 OBJECTNAME VARCHAR(65),
 SUMINSURED INT,
 INSURANCERISK VARCHAR(65),
 INSURANCEVZNOS INT, 
INSURANCETIMEACTIVITY DATE,
INSURANCETIMEACTIVITYFINAL DATE,
 DOCUMENTNUMBER INT NOT NULL,
CONFIRMDOCUMENT VARCHAR(65),
INSURANCEPAYMENT INT,
DATEPAYMENT DATE,
 PRIMARY KEY (DOCUMENTNUMBER )
);


 и т.д.
PM MAIL   Вверх
LSD
Дата 9.12.2011, 11:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Цитата(zhenya1 @  8.12.2011,  23:48 Найти цитируемый пост)
Но вся проблема в том, что они никак между собой не связаны, а код вроде как уже написан. Как можно сделать осмысленные связи между ними, чтобы я по прежнему мог работать с ними как раньше?!

Что значит "как раньше"? Добавить ссылочную целостность не большая проблема, но если программа при вставке данных, не соблюдает ее, то работать ничего не будет.


--------------------
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   Вверх
zhenya1
Дата 9.12.2011, 16:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Можно ли сделать вот по такой схемке?! (см.ссылку)

http://s2.ipicture.ru/uploads/20111209/LGT4TJ24.png


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


Leprechaun Software Developer
****


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

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



Я не могу понять связь полей в старом варианте и новом, какое в какое должно перейти.


--------------------
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   Вверх
zhenya1
Дата 9.12.2011, 16:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



В страром варианте  не было связей , а было 7 независимых табличек с одинаковыми, по названию, полями.
PM MAIL   Вверх
LSD
Дата 9.12.2011, 17:00 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Где в старых таблицах НаименованиеВидаСтрахования?

Добавлено через 2 минуты и 6 секунд
В любом случае что можно сделать легко: 
- разбить данные на несколько таблиц
- воссоздать старую структуру с помощью view

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


--------------------
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   Вверх
zhenya1
Дата 9.12.2011, 17:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Буду пробывать. Спасибо за внимание!
PM MAIL   Вверх
Zloxa
Дата 9.12.2011, 17:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(LSD @  9.12.2011,  17:00 Найти цитируемый пост)
загнать всю необходимую логику в триггер

Это тоже может потребовать модификации клиента. Не все операции над таблами аналогичны для вьюх.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
LSD
Дата 9.12.2011, 17:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Цитата(Zloxa @  9.12.2011,  18:09 Найти цитируемый пост)
Это тоже может потребовать модификации клиента. Не все операции над таблами аналогичны для вьюх. 

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


--------------------
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   Вверх
Zloxa
Дата 9.12.2011, 19:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



LSD, я не о том, что нельзя. Я не раз подменял таблы вьюхами, но, зачастую, доводилось и обламываться, затрагивать и клиентскую часть.     Точно не припомню что именно не получилось и при каких условиях, но вроде как мержи  переставали во вьюху работать, for update накинуть не удавалось, rowid забрать. Т.е. таки не все, что можно сделать с таблой, можно сделать и со вьюхой. И таких случаев, к сожалению, в моей практике в достатке. Так, что если таки удастся не затрагивать клиента, я полагаю это почитай повезло.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

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

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

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

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


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

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

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

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

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


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

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


 




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


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

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