![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
|
Зравствуйте всем.
Препод поставил задание- создать небольшую экспертную систему, которая бы давала советы пользователю в зависимости от неисправности ПК. Обязательным условием является наличие БД с вопросами и ответами. Т.е. Пользователь отвечает на вопросы программы, которая в свою очередь выдаёт советы. Я не могу придумать нормалый способ извлечения вопросов и ответов из БД. Помогите люди, завтра сдавать, а я уже 3-й день бьюсь... Вот примерная схема работы - ссылка : http://imageshost.ru/photo/41122/id1154631.html Вариантами выборки из бд, советами, хоть чем нибудь И мой ДИКИЙ и не завершенный код..... который к тому же еще и не работает как надо ![]() Код:
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls, ExtCtrls, DB, IBCustomDataSet, IBQuery, IBDatabase,
Grids, DBGrids;
type
TForm1 = class(TForm)
RadioGroup1: TRadioGroup;
Button1: TButton;
Label1: TLabel;
IBDatabase1: TIBDatabase;
IBTransaction1: TIBTransaction;
IBQuery1: TIBQuery;
DataSource1: TDataSource;
Button3: TButton;
IBQuery2: TIBQuery;
Button2: TButton;
Button4: TButton;
procedure Button1Click(Sender: TObject);
procedure RadioGroup1Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure Button4Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
IdxQuestion:integer = 1; PushRadioButton:string; IdxAnswer:integer = 0;
implementation
{$R *.dfm}
procedure TForm1.Button1Click(Sender: TObject);
begin
case IdxQuestion of
1:if (IBQuery1.FieldByName('Question').AsString='Компьютер работает?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=2
else
Begin
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=:ID');
IBQuery2.Prepare;
IBQUery2.ParamByName('ID').AsInteger:=1;
IBQuery2.Open;
ShowMessage(IBQuery2.FieldByName('Answer').AsString)
End;
2:if (IBQuery1.FieldByName('Question').AsString='Компьютер включается?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=3 else IdxQuestion:=4;
3:if (IBQuery1.FieldByName('Question').AsString='Электричество есть?') and (RadioGroup1.ItemIndex=0)
then
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=5');
IBQuery2.Open;
ShowMessage(IBQuery2.FieldByName('Answer').AsString);
else
Begin
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=3');
IBQuery2.Open;
ShowMessage(IBQuery2.FieldByName('Answer').AsString);
End;
4:if (IBQuery1.FieldByName('Question').AsString='Изображение есть на мониторе?') and (RadioGroup1.ItemIndex=0)
then IdxQuestion:=7 else IdxQuestion:=5;
5:if (IBQuery1.FieldByName('Question').AsString='Монитор подключен к сети?') and (RadioGroup1.ItemIndex=0)
then IdxQuestion:=6
else
Begin
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=5');
IBQuery2.Open;
ShowMessage(IBQuery2.FieldByName('Answer').AsString);
End;
6:if (IBQuery1.FieldByName('Question').AsString='Лампочка на мониторе горит?') and (RadioGroup1.ItemIndex=0)
then ShowMessage(IBQuery2.FieldByName('Answer').AsString) else ShowMessage(IBQuery2.FieldByName('Answer').AsString);
7:if (IBQuery1.FieldByName('Question').AsString='Есть писк при загрузке ОС?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=8 else ShowMessage(IBQuery2.FieldByName('Answer').AsString);
8:if (IBQuery1.FieldByName('Question').AsString='Загружается ОС?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=9 else IdxQuestion:=10;
9:if (IBQuery1.FieldByName('Question').AsString='Есть сообщение об ошибке ОС?') and (RadioGroup1.ItemIndex=0)
then ShowMessage(IBQuery2.FieldByName('Answer').AsString) else ShowMessage(IBQuery2.FieldByName('Answer').AsString);
10:if (IBQuery1.FieldByName('Question').AsString='При входе в систему есть звук?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=11 else IdxQuestion:=12;
11:if (IBQuery1.FieldByName('Question').AsString='У вас есть звуковая карта?') and (RadioGroup1.ItemIndex=1)
then IdxQuestion:=12 else ShowMessage(IBQuery2.FieldByName('Answer').AsString);
12:if (IBQuery1.FieldByName('Question').AsString='Система загрузилась без ошибок?') and (RadioGroup1.ItemIndex=0)
then ShowMessage(IBQuery2.FieldByName('Answer').AsString) else ShowMessage(IBQuery2.FieldByName('Answer').AsString);
End;
RadioGroup1.ItemIndex:=-1;
Button1.Enabled:=False;
IBQuery1.Close;
IBQuery1.SQL.Clear;
IBQuery1.SQL.Add('select Question from Questions where QestionIDMain=:ID');
IBQuery1.Prepare;
IBQUery1.ParamByName('ID').AsInteger:=IdxQuestion;
IBQuery1.Open;
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=:ID');
IBQuery2.Prepare;
IBQUery2.ParamByName('ID').AsInteger:=IdxAnswer;
IBQuery2.Open;
Label1.Caption:=IBQuery1.FieldByName('Question').AsString;
End;
procedure TForm1.RadioGroup1Click(Sender: TObject);
begin
If RadioGroup1.ItemIndex >= 0 then Button1.Enabled:=True;
end;
procedure TForm1.Button3Click(Sender: TObject);
begin
Form1.Close;
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
IBQuery1.Close;
IBQuery1.SQL.Clear;
IBQuery1.SQL.Add('select Question from Questions where QestionIDMain=:ID');
IBQuery1.Prepare;
IBQUery1.ParamByName('ID').AsInteger:=IdxQuestion;
IBQuery1.Open;
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=:ID');
IBQuery2.Prepare;
IBQUery2.ParamByName('ID').AsInteger:=IdxAnswer;
IBQuery2.Open;
Label1.Caption:=IBQuery1.FieldByName('Question').AsString;
Button1.Enabled:=True;
Button4.Enabled:=True;
end;
procedure TForm1.Button4Click(Sender: TObject);
begin
IdxQuestion:=1;
IdxAnswer:=1;
IBQuery1.Close;
IBQuery1.SQL.Clear;
IBQuery1.SQL.Add('select Question from Questions where QestionIDMain=:ID');
IBQuery1.Prepare;
IBQUery1.ParamByName('ID').AsInteger:=IdxQuestion;
IBQuery1.Open;
Label1.Caption:=IBQuery1.FieldByName('Question').AsString;
IBQuery2.Close;
IBQuery2.SQL.Clear;
IBQuery2.SQL.Add('select Answer from Answers where AnswerIDMain=:ID');
IBQuery2.Prepare;
IBQUery2.ParamByName('ID').AsInteger:=IdxAnswer;
IBQuery2.Open;
Button4.Enabled:=False;
end;
end. |
|
#2
|
|||
|
|||
|
Задание явно не на три дня, так что сразу делать надо было
|
|
#3
|
|||
|
|||
|
Цитата:
![]() Последний раз редактировалось Yo_Asakyra, 18.12.2011 в 20:15. |
|
#4
|
|||
|
|||
|
Ну в делфи куча возможностей. ADO к примеру
|
|
#5
|
|||
|
|||
|
Самый простой вариант - сделать на продукционных правилах, т.е. правилах ЕСЛИ-ТО. Тогда схема для БД будет примерно такая:
Код:
CREATE TABLE RULE ( ID INTEGER PRIMARY KEY, NAME VARCHAR(100) ); CREATE TABLE IFCLAUSE ( ID INTEGER PRIMARY KEY, RULE_ID INTEGER REFERENCE RULE(ID), QUESTION VARCHAR(255), VAR_NAME : VARCHAR(100) ); CREATE TABLE THENCLAUSE ( ID INTEGER PRIMARY KEY, RULE_ID INTEGER REFERENCE RULE(ID), VAR_NAME VARCHAR(100), VAR_VALUE VARCHAR(100) ); Работает примерно так. Выбираешь правило (можно любое). Начинаешь анализировать IFCLAUSE. Если переменная в IFCLAUSE есть где-нить в THENCLAUSE, то начинаешь обрабатывть соотв. правило. Если такой ситуации нет, то задаешь вопрос пользователю. Ну и так, пока причина не будет найдена. ЗЫ. Хотя тут релационная БД в общем не пришей кобыле хвост. Только как хранилище базы и то, не самое удобное. |