Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Создание динамических баз данных





 

Достоинством Пролога является простота создания динамических баз данных. Основной задачей систем управления баз данных СУБД является добавление, удаление и корректирование записей в базе. Как известно из курса «Информационные системы», самая распространенная модель данных – реляционная.

Данные в реляционной базе данных представляются в виде таблицы. Под каждую запись в БД отводится одна строка, которая рассматривается как элемент отношения. Число элементов отношения является мощностью отношения. Число колонок (полей) в записи называется арностью. Имя колонки является атрибутом. Например, табличный список студентов:

ФИО Группа № студента

 

Фамилия, группа и номер образуют запись в базе, которую можно определить предикатом dstudent (name, groupe, position). Таким образом, можно установить следующие соответствия:

База данных Турбо Пролога Реляционная база
Предикат базы Отношение
Объект Атрибут
Отдельное утверждение Элемент отношения
Количество утверждений Мощность
Имя предиката Имя таблицы

 

Для работы с базами данных в Прологе имеются следующие встроенные предикаты.

1. asserta – заносит новый факт в базу данных (БД) в?????(ОЗУ). Заносит так, что новый факт помещается перед всеми ранее внесенными фактами.

2. assertz – помещает новый факт в конец БД.

Например.

assertbase: - student (name, group, number),

assertz (dstudent (name, group, number)),

fail.

assertbase: -!.

3. retract – удаляет утверждение из БД (удаляет конкретную запись)

Например, из записи убрать конкретного студента:

Retract (dstudent («Иванов», 461, 5))

Предикаты для работы с базой в целом:

4. save – предикат, сохраняющий БД на диске из ОЗУ.

save (Dos_filename) – сохраняет из ОЗУ на диске.

5. consult (Dos_filename) – считывает базу из файла на диске в ОЗУ. Consult неуспешен, если нет файла, неправильный синтаксис описания, нельзя разместить в ОЗУ из-за недостатка места.

6. readterm (Domain, Term) – считывает из файла объекты, относящиеся к определенному домену: readterm(auto_record,auto(Name, Year, Price))

Пример:

domains

name = string

group = integer

number = integer

student(name, group, number)

readterm(dstudent, student(name, groupe, number))

Для получения списка всех студентов можно использовать предикат findall(Name, dstudent(Name, _, _), Namelist). Переменная Namelist будет содержать список всех имен.

При проектировании БД необходимо учитывать следующие факторы.

1. Размер БД (для того, чтобы выбрать, где будет делаться база в ОЗУ или на диске).

2. Организация элементов БД.

3. Способы работы и содержание БД.

База данных создается в ОЗУ, если размер базы данных относительномал. Сначала необходимо задать начальные данные и создать базу. После того как БД создана, необходимо организовать её работу, которая включает следующее:

1. занесение новых данных,

2. удаление данных,

3. выборка и вывод данных на экран.

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

student(p_name, /* полное имя (string) */

G_number,/* номер группы */

Pos) /*номер в группе*/

Группа предикатов записывается в виде:

student(“Irina Fux, 484,5) и т.д.

Раздел domains

p_name=string

g_number,pos=integer

Предикаты динамической базы данных описываются в разделе Database:

dstudent (p_name, g_number, pos).

При запуске на выполнение, утверждения базы данных помещаются отдельно от обычных утверждений в оперативной памяти.

В разделе предикатов описываем все другие предикаты:

predicates

repeat

do_mbase

assert_database

menu

process(integer)

clear_database

student(p_name, g_number, pos)

error

Предикат student предназначен для задания начального содержимого базы данных. Эта информация засылается в утверждения предиката dstudent.

База данных «Студенты».

domains

p_name=string

g_number, pos=integer

database

dstudent(p_name, g_number, pos)

predicates

repeat

do_mbase

assert_database

menu

process(integer)

clear_database

student(p_name, g_number, pos)

error

goal

do_mbase

clauses

repeat

repeat:-repeat,

student(“Ivan Ivanov”, 543, 3)

student(.......)

assert_database:– student(P_name, G_name,Pos), assertz(dstudent(P_name, G_name, Pos), fail.

assert_databse:–!.

сlear_database:– retract(dstudent(_,_,_)), fail.

сlear_database:–!.

вo_mbase:– assert_database, makewindow(1, 7, 7, “Student Base”, 0, 0, 25, 80), menu, clear_database.

Menu:– repeat, clearwindow, write(«Text of help»), write(«Input choice(1,2,3,4):”), readint(Choice), nl, process(Choice), Choice=4,!.

Process(1):– makewindow(2, 7, 7, “Add student to base”, 2, 20, 18, 58), shiftwindow(2), write(“Input Name”), readln(P-name), write(“Input group”), readint(G-number), write(“Input number”), readint(Pos), assertz(dstudent(P_name, G_number, Pos)), write(P_name, “add to base”), nl,!, write(“press space”), readchar(_), removewindow.

Process(2):– makewindow(3, 7, 7, “Deleting”, 10, 30, 7, 40), shiftwindow(3), write(“Input Name”), readln(P_name), retract(dstudent(P_name,_,_)), write(P_name, “Deleted”), nl,!, write(“Press space”), readchar(_), removewindow.

Process(3):– makewindow(4, 7, 7, “review”, 7, 30, 16, 47), shiftwindow(4), write(“Input Name”), readln(P_name), dstudent(P_name, G_number, Pos), nl, write(“Name of student:”, P_name), write(“Group”, G_number), write(“Position”, Pos), nl, nl,!, write(“Space”), readchar(_), removewindow).

Process(3):– makewindow(5, 7, 7, ”Nobody”, 14, 7, 5, 60), shiftwindow(3), write(“Cant find”), nl, nl, write(“Sorry”), nl,!, write(“Space”), readchar(_), removewindow, shiftwindow(1).

Process(4):– write(“Are you shure?/Y/N”), readln(Answer), frontchar(Answer, ’Y’,_),!.

Process(Choice):– Choice<1, error.

Process(Choice):– Choice>4, error.

Error:– write(“Input number from 1 to 4”), write (“Space”), readchar(_).

Базы данных можно хранить и на внешних носителях. В этом случае к вышеприведенной программе добавляются правила чтения и записи внешних файлов. Вспомогательные модули dbassert и dbass заносят в базу новые данные. Вводятся два терма, обозначающие файл базы данных и служебный индексный файл.

domains

file=datafile; indexfile

name=string

group=integer

database

team(name, group)

predicates

repeat

menu

process(integer)

do_base

dbassert(dbasedom) – содержит ссылки на файл базы данных и служебный файл

dbass(dbaedom, string, string)

dbretract(dbasedom)

dbret(dbasedom, string, string) – ищет запись и удаляет

dbret1(dbasedom, real)

dbread(dbasedom)

dbrd(dbasedom, string, string) – ищет и читает данные

dbaaccess(dbasedom, real) –ищет и читает в индексном файле

goal

do_dbase

clauses

co_dbase:– makewindow(1, 7, 7, “Kurse”, 0, 0, 24, 80), menu.

menu:–repeat, clearwindow, nl, write(“1.add 2delete 3 review 4 exit”), nl, write(“Input choice 1 2 3 4”), readint(Choice), nl, Choice>0, Choice<5, process(Choice), Choice=4,!.

Process(1): – аналогично предыдущей программе/

7.19. Библиотеки Turbo Prolog’а

 

Штатные средства языка Турбо Пролог достаточны только для того, чтобы писать на нем учебные программы. Для решения научных задач их недостаточно, поэтому разработчики программного обеспечения дополняют эти средства специальными библиотеками программ. Для использования например BGI-графики, т.е. стандартной Borland-графики в Турбо Прологе необходимо в разделе constants определить маршрут для bgi-модулей в виде

Constants bgi_path=”e:\\prolog\\bgi”

где указывается каталог, в котором находятся bgi-модули, затем подключить модуль описаний

include”e:\\prolog\\programs\\GRAPDECL.PRO”.

После этого в предикате необходимо инициализировать графику предикатом

initgraph(detect, 0, Graphdriver, Graphmode, bgi_path).

После такой инициализации становятся доcтупными предикаты стандартной Borland-графики, например:

· arc(x, y, beg, end, r) – дуга с центром в (х, у), с углом (end-beg) и радиусом r.

· line(xstart, ystart, xend, yend) – линия с начальной и конечной точками.

· circle(x, y, r) – круг с центром в точке (х, у) и радиусом r.

· rectangle(x1, y1, x2, y2) – прямоугольник с координатами противоположных вершин.

· outtextxy(x, y, Title) – вывод текста Title, начиная с точки (х, у).

· Полный список доступных операторов можно найти в справке Help.

· Пример организации движения слов в Прологе.

· сonstants

· bgi_path=”e:\\prolog\\prolog\\bgi”

· include “e:\\prolog\\prolog\\programs\\GRAPDECL.PRO”

· Predicates

· dvig(integer, string)

· dvi(integer, string)

· goal

· initgraph(detect, 0, GraphDriver, PraphMode, bgi_path), setbkcolor(3), setcolor(12),

· settextstyle(0, 0, 3), outtextxy(10, 50, “волк”), outtextxy(10, 70, “коза”), outtextxy(10, 90, «капуста»),

· outtextxy(10, 110, “один”), getimage(10, 50, 100, 70,X), dvig(1, X),

· getimage(10, 70, 100, 90, Y), dvig(1, Y), getimage(10, 90, 100, 110, Z), dvi(500, Z), readchar(_),

· closegraph.

· clauses

· dvig(500,_).

· dvig(A,X):–putimage(A, 0, X, 1), putimage(A, 0, X, 1), A1=A+1, A<500, dvig(A1, X).

· dvi(1,_).

· dvi(A,X):–putimage(A, 0, X, 1), putimage(A, 0, X, 1), A1=A-1, A>1, dvi(A1, X).

·







Дата добавления: 2015-10-19; просмотров: 1198. Нарушение авторских прав; Мы поможем в написании вашей работы!




Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...


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


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Кишечный шов (Ламбера, Альберта, Шмидена, Матешука) Кишечный шов– это способ соединения кишечной стенки. В основе кишечного шва лежит принцип футлярного строения кишечной стенки...

Принципы резекции желудка по типу Бильрот 1, Бильрот 2; операция Гофмейстера-Финстерера. Гастрэктомия Резекция желудка – удаление части желудка: а) дистальная – удаляют 2/3 желудка б) проксимальная – удаляют 95% желудка. Показания...

Ваготомия. Дренирующие операции Ваготомия – денервация зон желудка, секретирующих соляную кислоту, путем пересечения блуждающих нервов или их ветвей...

Меры безопасности при обращении с оружием и боеприпасами 64. Получение (сдача) оружия и боеприпасов для проведения стрельб осуществляется в установленном порядке[1]. 65. Безопасность при проведении стрельб обеспечивается...

Весы настольные циферблатные Весы настольные циферблатные РН-10Ц13 (рис.3.1) выпускаются с наибольшими пределами взвешивания 2...

Хронометражно-табличная методика определения суточного расхода энергии студента Цель: познакомиться с хронометражно-табличным методом опреде­ления суточного расхода энергии...

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия