Помощь - Поиск - Пользователи - Календарь
Полная версия: C#.Логические выражения.
Форум «Всё о Паскале» > Современный Паскаль и другие языки > Ада и другие языки
Fanat
Возникла необходимость создать некую БД вопросов и ответов.
Вопросы и ответы хранятся в SQL Server. 1 вопрос - несколько ответов.

При этом для каждого вопроса можно задать условия при котором его следует задавать.
Что-то типа:
(((если на первый вопрос дан ответ1) И (если на второй вопрос дан ответ2))
ИЛИ
(если на первый вопрос дан ответ2)) тогда задаём вопрос 3.

Как лучше хранить эти условия в БД? Строкой или какой-то сложной структурой?
И как лучше организовать проверку этих условий? Может есть какие-то стандартные средства?
Client
немного странно.
ты не знаешь условия этих вопросов? если знаешь то привяжи их в коде, а в базе оставь вопросы/ответы.

если этих условий пара, то можно добавить пару полей в таблицу или сделать отдельную таблицу и в ней хранить условия, или хранить условие строкой и парсить ее. Тут все дело за реализацией способа, как проще так наверно и делай smile.gif
Lapp
Нет, в коде не надо.. Код и данные должны быть полностью развязаны.
Второй способ, предложенный Client, значительно лучше. Да, нужно в каком-то виде задавать сами условия и держать их в базе. Например, в виде строки. Пример из первого поста можно задать как-то так:

q1a1*q2a2/q1a2=q3

(буквы нужны как разделители на случай, когда вопросов/ответов больше 10)
Fanat
Согласен с вашими предложениями.
Условия надо хранить в базе, потому что их можно редактировать. То есть в коде привязывать нельзя. Тоже подумал про хранение строкой.
Думал может есть какие-то более интересные варианты. smile.gif
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.