AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Администрирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 02.09.2008, 10:05   #1  
Гужанов Павел is offline
Гужанов Павел
Участник
 
2 / 10 (1) +
Регистрация: 02.09.2008
Принципы построения базы данных
Здравствуйте.

В организации, где я работаю, идет внедрение Axapta. Нас, программистов, посылали на курсы. Компанию, которая нас обучала, здесь называть не буду. В процессе учебы смутило следующее: было сказано, что в Axapta вся логика выведена из базы в приложение. Т.е. в базе данных нет генераторов, триггеров, внешних ключей... а вся генерация, проверка целостности данных и прочее производится непосредственно в приложении. Скажите, так ли это? Или это просто некомпетентность обучающих?
На мой взгляд, если делать действительно так, то каждый модуль приложения будет неоправданно увеличиваться в объеме, да и вообще, неверно это, логика работы базы должно реализовываться в базе.
Старый 02.09.2008, 10:37   #2  
Vadik is offline
Vadik
Модератор
Аватар для Vadik
Лучший по профессии 2017
Лучший по профессии 2015
 
3,631 / 1849 (69) ++++++++
Регистрация: 18.11.2002
Адрес: гражданин Москвы
Цитата:
Компанию, которая нас обучала, здесь называть не буду. В процессе учебы смутило следующее: было сказано, что в Axapta вся логика выведена из базы в приложение. Т.е. в базе данных нет генераторов, триггеров, внешних ключей... а вся генерация, проверка целостности данных и прочее производится непосредственно в приложении. Скажите, так ли это?
так

Цитата:
На мой взгляд, если делать действительно так, то каждый модуль приложения будет неоправданно увеличиваться в объеме, да и вообще, неверно это, логика работы базы должно реализовываться в базе
"Люди базы" часть вторая ? Нормально все с бизнес-логикой, не переживайте
__________________
-ТСЯ или -ТЬСЯ ?
Старый 02.09.2008, 10:39   #3  
MikeR is offline
MikeR
MCT
Аватар для MikeR
MCBMSS
Лучший по профессии 2015
Лучший по профессии 2014
 
1,628 / 627 (24) +++++++
Регистрация: 28.11.2005
Адрес: просто землянин
Скорее всего речь шла об использовании прямых запросов и использование вычислительных ресурсов на сервере базы данных. Это актуально в таких приложениях как 1С.
__________________
Axapta book for developer
Старый 02.09.2008, 10:42   #4  
Михаил Андреев is offline
Михаил Андреев
Участник
Компания АМАНД
Лучший по профессии 2009
 
1,295 / 239 (10) ++++++
Регистрация: 09.11.2001
Адрес: Химки, Московская область
Цитата:
Сообщение от Гужанов Павел Посмотреть сообщение
На мой взгляд, если делать действительно так, то каждый модуль приложения будет неоправданно увеличиваться в объеме, да и вообще, неверно это, логика работы базы должно реализовываться в базе.
Неправильный вывод. Все связи контролирует ядро, которое едино для всех модулей.
__________________
Михаил Андреев
https://www.amand.ru
Старый 02.09.2008, 11:10   #5  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от Гужанов Павел Посмотреть сообщение
Т.е. в базе данных нет генераторов, триггеров, внешних ключей... а вся генерация, проверка целостности данных и прочее производится непосредственно в приложении. Скажите, так ли это?
Так. Обсуждалось неоднократно на форуме. Поищите.
А также ветка на sql.ru, в которой я принимал участие
http://sql.ru/forum/actualthread.aspx?tid=105796
__________________
полезное на axForum, github, vk, coub.
Старый 02.09.2008, 11:12   #6  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
На самом деле, насколько я понимаю, действительно было бы более разумным использовать приемущества и существующие средства самой базы данных.
Думаю, причина, по которой это сделано не так, проста - на тот момент, когда это делалось, пришлось бы выбирать: либо поддержка нескольких СУБД, либо привязка к только одной, и использование ее встроенных средств.

Сейчас СУБД, используемые АХ (Оракл и СКЛ) обе обеспечивают все необходимые функции, поэтому, возможно, когда-то мы будем использовать и внешние ключи, и триггера
Старый 02.09.2008, 11:41   #7  
Гужанов Павел is offline
Гужанов Павел
Участник
 
2 / 10 (1) +
Регистрация: 02.09.2008
Раз в базе не реализована никакая бизнес-логика, то возможна такая ситуация: В базу заходит человек с правами sa, но с нулевым пониманием того, что он делает.(не надо спрашивать у меня, откуда у него такие права :о)) Заходит не из приложения, а используя SQL Server Management Studio. Спокойно удаляет все данные из одной таблицы. В других таблицах остаются данные, которые ссылаются на удаленные данные, но, т.к. внешних ключей нет, получается нарушенная целостность. Имхо, "защиту от дурака" все-таки лучше реализовать на сервере БД, это защищает и от попыток что-то сломать из приложения, и от таких же попыток непосредственно на сервере БД.
Старый 02.09.2008, 11:50   #8  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от Гужанов Павел Посмотреть сообщение
Раз в базе не реализована никакая бизнес-логика, то возможна такая ситуация: В базу заходит человек с правами sa, но с нулевым пониманием того, что он делает.(не надо спрашивать у меня, откуда у него такие права :о)) Заходит не из приложения, а используя SQL Server Management Studio. Спокойно удаляет все данные из одной таблицы. В других таблицах остаются данные, которые ссылаются на удаленные данные, но, т.к. внешних ключей нет, получается нарушенная целостность.
Такая ситуация возможна.

Цитата:
Сообщение от Гужанов Павел Посмотреть сообщение
Имхо, "защиту от дурака" все-таки лучше реализовать на сервере БД, это защищает и от попыток что-то сломать из приложения, и от таких же попыток непосредственно на сервере БД.
Вообще говоря "защиту от дурака" лучше реализовывать на аппаратном или еще лучше на административном уровне.

Представьте что на сервер заходит человек с правами administrator (не надо спрашивать, откуда у него такие права ), останавливает сервис MS SQL и (о, ужас!) удаляет файлы с расширением mdf...

Вывод: тщательно думайте когда раздаете права.
__________________
полезное на axForum, github, vk, coub.
Старый 02.09.2008, 11:51   #9  
Weez is offline
Weez
Участник
Axapta Retail User
 
250 / 84 (3) ++++
Регистрация: 18.01.2006
Адрес: Moscow city
Бекапы никто не отменял
На самом деле бизнес-логика в Аксапте не огрничивается простыми связями между таблицами, не уверен, что можно посмотроить ту же логику в СУБД, что и в приложении Аксапты. А если и можно - то это потребует колоссальных трудозатрат при поддержке. ИМХО.
__________________
Существует 10 типов людей: одни понимают двоичную систему, другие - нет.
Старый 02.09.2008, 12:03   #10  
coolibin is offline
coolibin
Участник
 
264 / 68 (3) ++++
Регистрация: 07.04.2005
Цитата:
Представьте что на сервер заходит человек с правами administrator (не надо спрашивать, откуда у него такие права ), останавливает сервис MS SQL и (о, ужас!) удаляет файлы с расширением mdf...
представьте, что в серверную заходит бородатый мужик с топором... и не спрашивайте, где он топор взял...
Старый 02.09.2008, 12:08   #11  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от coolibin Посмотреть сообщение
представьте, что в серверную заходит бородатый мужик с топором... и не спрашивайте, где он топор взял...
А это уже не байки.
В серверную заходит мужик в маске и с автоматом. Тут и не спросишь
__________________
полезное на axForum, github, vk, coub.
За это сообщение автора поблагодарили: Poleax (1).
Старый 05.09.2008, 16:47   #12  
somebody is offline
somebody
Участник
 
128 / 30 (2) +++
Регистрация: 30.04.2003
Адрес: Москва
Цитата:
Сообщение от Гужанов Павел
логика работы базы должна реализовываться в базе.
"Работает" приложение, а база просто хранит данные, да и то не все (часть информации, как-то перечисления, мапы и др., хранится в приложении), а серверный движок выполняет указания приложения по обработке данных.
Вообще ведь использование "низкоуровневых" возможностей БД не запрещено (вызов ХП, например, часто используется). Но часть из них (триггер...), просто не переживёт синхронизацию.
Цитата:
Сообщение от Weez
не уверен, что можно посмотреть ту же логику в СУБД, что и в приложении Аксапты.
Конечно, нет, см. выше. Например, связи прописаны в приложении, а можно вообще реализовать их только в кодах XPP.
Цитата:
Сообщение от Гужанов Павел
В базу заходит человек с правами sa, но с нулевым пониманием того, что он делает.
Дак и в Аксапту может зайти человек с админскими правами и нулевым пониманием (не спрашивайте и т. д.!..) и такого там наворотить...
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
SysSQLBlockingMSSQL - форма Блокировки пользователей базы данных DenisS DAX: Программирование 6 18.08.2009 17:23
Утилиты для работы с журналом базы данных vc DAX: База знаний и проекты 0 10.05.2008 17:40
Вопрос по журналу базы данных(лог) Hidden DAX: Функционал 2 21.09.2005 14:00
Имя сервера и базы данных mne2001 DAX: Программирование 1 01.04.2005 12:54
Уменьшение базы данных Axapta Writer DAX: Администрирование 13 15.09.2003 16:53

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 20:15.