IPB
ЛогинПароль:

> Внимание!

1. Пользуйтесь тегами кода. - [code] ... [/code]
2. Точно указывайте язык, название и версию компилятора (интерпретатора).
3. Название темы должно быть информативным.
В описании темы указываем язык!!!

Наладить общение поможет, если вы подпишитесь по почте на новые темы в этом форуме.

 
 Ответить  Открыть новую тему 
> C#.Логические выражения.
сообщение
Сообщение #1


Fanat
***

Группа: Пользователи
Сообщений: 261
Пол: Мужской
Реальное имя: Сергей

Репутация: -  5  +


Возникла необходимость создать некую БД вопросов и ответов.
Вопросы и ответы хранятся в SQL Server. 1 вопрос - несколько ответов.

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

Как лучше хранить эти условия в БД? Строкой или какой-то сложной структурой?
И как лучше организовать проверку этих условий? Может есть какие-то стандартные средства?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


Профи
****

Группа: Пользователи
Сообщений: 865
Пол: Мужской
Реальное имя: Вячеслав

Репутация: -  20  +


немного странно.
ты не знаешь условия этих вопросов? если знаешь то привяжи их в коде, а в базе оставь вопросы/ответы.

если этих условий пара, то можно добавить пару полей в таблицу или сделать отдельную таблицу и в ней хранить условия, или хранить условие строкой и парсить ее. Тут все дело за реализацией способа, как проще так наверно и делай smile.gif
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Уникум
*******

Группа: Пользователи
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

Репутация: -  159  +


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

q1a1*q2a2/q1a2=q3

(буквы нужны как разделители на случай, когда вопросов/ответов больше 10)


--------------------
я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4


Fanat
***

Группа: Пользователи
Сообщений: 261
Пол: Мужской
Реальное имя: Сергей

Репутация: -  5  +


Согласен с вашими предложениями.
Условия надо хранить в базе, потому что их можно редактировать. То есть в коде привязывать нельзя. Тоже подумал про хранение строкой.
Думал может есть какие-то более интересные варианты. smile.gif
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 5.05.2024 14:52
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name