Trong bài báo trước [9], chúng tôi đã
đề xuất một tiểu ngôn ngữ truy vấn có yếu tố
thời gian SubTSQL để truy vấn và thao tác dữ
liệu trên cơ sở dữ liệu thời gian. Bài báo này
chúng tôi sử dụng mã nguồn mở Lex và Yacc
để xây dựng một trình biên dịch, trình biên
dịch này làm công việc biên dịch câu truy
vấn thời gian thành câu SQL trong Oracle.
Một trình biên dịch như thế dễ dàng tạo lập
và giảm tải cho người lập trình
8 trang |
Chia sẻ: luyenbuizn | Lượt xem: 1375 | Lượt tải: 0
Nội dung tài liệu Biên dịch câu truy vấn thời gian, thực thi trên hệ quản trị cơ sở dữ liệu, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Khoa hoïc - kó thuaäät
37
*
TOÙM TAÉT:
Trong baøi baùo tröôùc [9], chuùng toâi ñaõ
ñeà xuaát moät tieåu ngoân ngöõ truy vaán coù yeáu toá
thôøi gian SubTSQL ñeå truy vaán vaø thao taùc döõ
lieäu treân cô sôû döõ lieäu thôøi gian. Baøi baùo naøy
chuùng toâi söû duïng maõ nguoàn môû Lex vaø Yacc
ñeå xaây döïng moät trình bieân dòch, trình bieân
dòch naøy laøm coâng vieäc bieân dòch caâu truy
vaán thôøi gian thaønh caâu SQL trong Oracle.
Moät trình bieân dòch nhö theá deã daøng taïo laäp
vaø giaûm taûi cho ngöôøi laäp trình.
ABSTRACT:
In [9] we proposed the temporal
query sublanguage SubTSQL that can work
with temporal database. In this paper, we
present to use Open source code Lex and
Yacc that can support a complier so that the
complier is easily built and reducing the
working of programmer. This complier can
convert temporal queries to Oracle SQL
queries
1. GIÔÙI THIEÄU
Thöïc teá, nhieàu öùng duïng treân cô sôû
döõ lieäu (CSDL), maø caùc ñoái töôïng trong
CSDL ñoù caàn gaén theâm yeáu toá thôøi gian [3].
Ví duï: nhöõng öùng duïng nhö: ngaân haøng, lòch
chuyeán bay, quaûn lyù kho haøng, hoà sô beänh
vieän, thò tröôøng chöùng khoaùn v.v..., thì yeáu
toá thôøi gian gaén vôùi ñoái töôïng
* Khoa Công nghệ Thông tin, Trường Đại học Công nghiệp TP.
HCM
laø moät thöïc teá (ñoái töôïng thay ñoåi döõ lieäu
theo thôøi gian), caàn coù noù ñeå taêng möùc
phong phuù vaø ngöõ nghóa cuûa döõ lieäu trong
CSDL [4], [5], [9].
Hieän taïi, chöa coù moät heä quaûn trò cô
sôû döõ lieäu (HQTCSDL) naøo hoã trôï moät caùch
coù heä thoáng cho vieäc truy xuaát hay thao taùc
döõ lieäu treân CSDL höôùng thôøi gian. Ngay
caû Oracle 10g thì nhöõng caâu leänh coù hoã trôï
thôøi gian cuõng khaù phöùc taïp, ngöôøi duøng
caàn söû duïng nhieàu haøm thö vieän trong caâu
truy vaán, hôn nöõa ñeå coù moät phieân baûn
chính thöùc cuûa Oracle 10g toán chi phí raát
cao. Caâu truy vaán coù yeáu toá thôøi gian, neáu
ñöôïc vieát theo cuù phaùp cuûa moät HQTCSDL
thì phöùc taïp (xem caâu truy vaán trong muïc
4.1), ngay caû ñoái vôùi laäp trình vieân chuyeân
nghieäp. Ñeå ngöôøi duøng deã daøng vieát caâu
truy vaán thôøi gian, caàn xaây döïng moät trình
bieân dòch coù tính heä thoáng, cuõng nhö deã
daøng môû roäng noù ñeå bieân dòch cho nhieàu
daïng caâu truy vaán khaùc. Neáu vieát moät trình
bieân dòch nhö theá theo truyeàn thoáng, toán
keùm nhieàu chi phí. Do vaäy, söû duïng phaàn
meàm maõ nguoàn môû (PMMNM) laø moät
phöông phaùp khaû thi ñeå xaây döïng trình bieân
dòch. Hôn nöõa, Thuû töôùng chính phuû ñaõ pheâ
duyeät Döï aùn toång theå öùng duïng vaø phaùt
trieån PMMNM taïi Vieät Nam giai ñoaïn
2004-2008 (Quyeát ñònh soá 235/QÑ-TTg
ngaøy 02/02/2004), moät trong nhöõng
noäi dung quan troïng cuûa döï aùn laø ñaåy maïnh
BIEÂN DÒCH CAÂU TRUY VAÁN THÔØI GIAN,
THÖÏC THI TREÂN HEÄ QUAÛN TRÒ CÔ SÔÛ DÖÕ LIEÄU
Phaïm Vaên Chung*
Khoa hoïc - kó thuaäät
38
vieäc öùng duïng caùc PMMNM trong trieån
khai caùc öùng duïng coâng ngheä thoâng tin taïi
caùc ñôn vò, caùc toå chöùc nhaø nöôùc cuõng nhö
trong caùc doanh nghieäp [8].
Baøi baùo naøy söû duïng PMMNM Lex
vaø Yacc ñeå xaây döïng boä vaên phaïm cho tieåu
ngoân ngöõ SubTSQL, maø chuùng toâi ñaõ ñeå
xuaát tröôùc ñaây, noù coù cuù phaùp ñôn giaûn gaàn
nhö caâu truy vaán thoâng thöôøng (chi tieát
SubTSQL xem trong [9]), vaø bieân dòch caâu
truy vaán SubTSQL, thaønh caâu truy vaán theo
cuù phaùp cuûa Oracle, sau ñoù duøng thö vieän
OCI ñeå keát noái HQTCSDL Oracle qua laäp
trình treân C++. Roäng hôn, coù theå truy vaán
döõ lieäu theo thôøi gian treân baát kyø
HQTCSDL naøo, mieãn laø ngoân ngöõ duøng ñeå
laäp trình cho pheùp keát noái ñeán HQTCSDL
ñoù. Phaàn coøn laïi cuûa baøi baùo goàm coù : Phaàn
2, xaây döïng trình bieân dòch baèng Lex vaø
Yacc. Phaàn 3, keát noái CSDL qua thö vieän
OCI. Phaàn 4, Hieän thöïc bieân dòch caâu truy
vaán thôøi gian treân CSDL beänh vieän vaø cuoái
cuøng laø keát luaän trong phaàn 5.
2. XAÂY DÖÏNG TRÌNH BIEÂN
DÒCH DUØNG LEX VAØ YACC
Xaây döïng trình bieân dòch
Xaây döïng moät trình bieân dòch theo
truyeàn thoáng (thoâng thöôøng) thöôøng toán raát
nhieàu coâng söùc. Caùc böôùc cô baûn maø moät
trình bieân dòch thoâng thöôøng phaûi thöïc hieän:
- Ñoïc chuoãi nhaäp vaø taùch thaønh caùc
token.
- Döïa vaøo vaên phaïm vaø caùc token
tieán haønh xaây döïng caây phaân tích cuù phaùp .
- Döïa vaøo caây phaân tích cuù phaùp ñeå
sinh ra maõ.
Caùc böôùc xaây döïng trình bieân dòch
ñöôïc minh hoïa nhö hình 1. Trong hình naøy,
chuoãi nhaäp seõ ñöôïc chuyeån qua boä phaân
tích töø vöïng ñeå phaân tích thaønh caùc token,
sau ñoù caùc token seõ ñöôïc chuyeån sang boä
phaân tích cuù phaùp, taïi ñaây döïa vaøo vaên
phaïm vaø caùc token, noù tieán haønh xaây döïng
caây phaân tích cuù phaùp. Cuoái cuøng, döïa vaøo
caây phaân tích cuù phaùp, boä sinh maõ seõ sinh
id3
Chuỗi nhập a = b + c * d
Token id1 = id2 + id3 * id4
Bộ phân tích cú pháp
Cây cú pháp =
Bộ sinh mã
id1 +
*
id4
id2
Sinh mã load id3
mul id4
add id2
store id1
Hình 1. Các bước mà một trình biên dịch thông thường thực hiện
Bộ phân tích từ vựng
Khoa hoïc - kó thuaäät
39
maõ töông öùng. Baøi baùo söû duïng Lex vaø
Yacc laø hai PMMNM khaù thoâng duïng, qui
trình xaây döïng trình bieân dòch ñöôïc trình
baøy trong nhöõng phaàn sau .
Xaây döïng trình bieân dòch duøng
LEX vaø YACC
Lex taïo ra boä phaân tích töø vöïng vôùi
maõ C/C++ hoaëc Java. Lex duøng caùc maãu
(pattern) ñeå so khôùp vôùi chuoãi nhaäp vaø bieán
ñoåi chuoãi nhaäp thaønh caùc token töông öùng.
Moät token coù moät maõ rieâng bieät nhaèm ñôn
giaûn hoaù coâng vieäc xöû lyù. Khi Lex nhaän ra
caùc danh hieäu (id) trong doøng döõ lieäu vaøo,
noù nhaäp chuùng vaøo baûng danh bieåu. Baûng
danh bieåu chöùa caùc thoâng tin khaùc nhö kieåu
döõ lieäu (integer, real,…) vaø vò trí cuûa bieán
trong boä nhôù. Moät khi danh hieäu ñöôïc söû
duïng, caùc thoâng tin lieân quan ñeán noù ñöôïc
truy xuaát thoâng qua chæ muïc trong baûng
naøy.
Yacc taïo ra boä phaân tích cuù phaùp vôùi
maõ C/C++ hoaëc Java. Yacc duøng caùc luaät
vaên phaïm maø moãi luaät cho pheùp phaân tích
caùc token töø keát quaû cuûa Lex vaø taïo ra caây
phaân tích cuù phaùp. Moät caây phaân tích cuù
phaùp aùp ñaët caáu truùc coù thöù töï leân caùc
token. Vieäc taïo ra caây phaân tích cuù phaùp laø
moät böôùc quan troïng maø moät trình bieân dòch
phaûi thöïc hieän nhö trong hình 1.
Quy trình xaây döïng moät trình bieân
dòch söû duïng Lex vaø Yacc [1],[4] ñöôïc
trình baøy nhö hình 4. Giaû söû, caàn vieát moät
trình bieân dòch coù teân laø bas. Duøng trình
soïan thaûo (coù theå laø Parser Generator 2,
cheùp töï do treân Internet), tröôùc tieân, xaùc
ñònh taát caû caùc luaät, keát hôïp vôùi caùc maãu
vaø ñaët chuùng trong taäp tin bas.l. cho Lex.
Tieáp ñeán vieát caùc luaät vaên phaïm vaøo taäp
tin bas.y cho YACC.
Nhieäm vuï cuûa Yacc laø ñoïc caùc luaät
vaên phaïm vaø ñònh nghóa caùc token, ghi
chuùng vaøo taäp tin bas.y vaø sinh ra boä phaân
tích cuù phaùp ñaët vaøo taäp tin y.tab.c, caùc
token cuõng ñöôïc ñònh nghóa trong taäp tin
y.tab.h. Nhieäm vuï cuûa Lex laø ñoïc caùc moâ
taû maãu trong taäp tin bas.l vaø caùc ñònh nghóa
token trong taäp tin y.tab.h ñeå taïo ra boä
phaân tích töø vöïng ghi vaøo taäp tin Lex.yy.c.
Cuoái cuøng, boä phaân tích töø vöïng vaø boä phaân
tích cuù phaùp ñöôïc bieân dòch (duøng trình bieân
dòch C/C++ hoaëc Java), taïo ra taäp tin thöïc
thi bas.exe.
Moãi luaät vaên phaïm khai baùo trong
taäp tin bas.y ñeàu coù moät haønh ñoäng ngöõ
nghóa töông öùng. Haønh ñoäng ngöõ nghóa
ñoùng vai troø nhö moät nhö boä sinh maõ. Quaù
trình sinh maõ coù nhieàu möùc, coù theå sinh maõ
trung gian hoaëc sinh ra moät maõ khaùc, maõ
maùy laø caáp sinh maõ thaáp nhaát, trong baøi baùo
naøy seõ sinh ra maõ trung gian laø caâu truy vaán
theo cuù phaùp cuûa Oracle.
Xaây döïng boä phaân tích töø vöïng söû
duïng Lex coù caáu truùc goàm 3 khoái nhö hình 2:
%{
Caùc khai baùo C (C declaration)
%%
Caùc luaät Lex (Lex rules)
%%
Phaàn maõ C (Additional C code)
Hình 2: Caáu truùc caùc khoái cho Lex
Trong hình 2, khoái khai baùo C ñöôïc
baét ñaàu bôûi %{ vaø keát thuùc bôûi }%; khoái
luaät Lex baét ñaàu bôûi %% vaø keát thuùc bôûi
%%; khoái maõ C vieát cuoái cuøng.
Töông töï, xaây döïng boä phaân tích cuù
phaùp söû duïng Yacc goàm 4 khoái, caùc khoái
ñöôïc phaân caùch bôûi caùc kyù hieäu ñoùng môû
khoái nhö hình 3, chi tieát veà moãi khoái cho
moãi caáu truùc, xem trong [1],[4],[7].
%{
Caùc khai baùo C (C declarations)
%}
Caùc khai baùo Yacc (Yacc declarations)
Khoa hoïc - kó thuaäät
40
Chương trình nguồn
Trình biên dịch của Host language
Tập tin đối tượng
Liên kết với OCI
Ứng dụng
Thư viện OCI
Oracle Sever
%%
Phaàn vaên phaïm (Grammar rules)
%%
Phaàn maõ C (Additional C code)
Hình 3: Caáu truùc caùc khoái cho Yacc
3. KEÁT NOÁI CÔ SÔÛ DÖÕ LIEÄU
DUØNG THÖ VIEÄN OCI
Tieán trình phaùt trieån moät öùng duïng
OCI
Oracle laø moät heä quaûn trò cô sôû döõ
lieäu lôùn coù beà daày thôøi gian vaø coù uy tín.
Tuy nhieân ñeå söû duïng troïn goùi, ngöôøi duøng
phaûi maát chi phí khaù lôùn. Thay vì phaûi mua
troïn goùi, ngöôøi duøng chæ mua heä quaûn trò cô
sôû döõ lieäu, khi ñoù chi phí seõ giaûm ñaùng keå.
Vieäc xaây döïng caùc coâng cuï ñeå keát
noái cô sôû döõ lieäu treân Oracle baèng ngoân ngöõ
C (C ñöôïc coi nhö laø moät host language)
döïa vaøo caùc haøm OCI [6] coù saün trong
Oracle laø moät giaûi phaùp khaû thi, vì chính
Oracle cuõng söû duïng OCI ñeå xaây döïng moät
soá coâng cuï cho noù.
OCI coù thö vieän khaù phong phuù, cho
pheùp ngöôøi duøng phaùt trieån caùc öùng duïng
truy caäp döõ lieäu khoâng thuû tuïc cuûa SQL
baèng laäp trình thuû tuïc treân C/Java. OCI hoã
trôï taát caû caùc caâu leänh ñònh nghóa döõ lieäu,
thao taùc döõ lieäu, truy vaán, khaû naêng ñieàu
khieån chuyeån taùc maø coù saün trong Oracle.
Hình 5 minh hoïa tieán trình phaùt trieån moät
öùng duïng OCI.
Yacc
Lex
Trình biên
dịch
C/C++
y.tab.c
bas.exe
Lex.yy.c
bas
y.tab.h
bas.y
bas.l
Hình 4. Quy trình xây dựng trình biên dịch sử
dụng Lex và Yacc
Hình 5: Tiến trình phát triển một ứng dụng
OCI
Khoa hoïc - kó thuaäät
41
Trong hình 5, töø chöông trình nguoàn,
tieán haønh bieân dòch baèng moät host
language, ñeå taïo ra caùc taäp tin ñoái töôïng,
caùc taäp tin naøy tieáp tuïc ñöôïc lieân keát vôùi thö
vieän OCI ñeå taïo öùng duïng, vaø öùng duïng coù
khaû naêng truy xuaát ñeán CSDL Oracle
server.
Caùc böôùc laäp trình baèng OCI
Ñeå keát noái CSDL duøng thö vieän
OCI, caàn thöïc hieän caùc böôùc sau: khôûi taïo
caùc tieán trình, khôûi taïo moâi tröôøng laøm vieäc,
caáp phaùt caùc handle vaø caùc caáu truùc döõ lieäu
caàn thieát vaø keát noái vôùi CSDL Oracle
server. Baét ñaàu phieân laøm vieäc, caáp phaùt
caâu leänh SQL vaø truy xuaát döõ lieäu. Keát thuùc
phieân laøm vieäc, ngöôøi duøng ngaét keát noái vôùi
Oracle server, khi ñoù caáu truùc döõ lieäu vaø
caùc handle ñöôïc giaûi phoùng. Hoaït ñoäng cuûa
OCI ñöôïc minh hoïa trong hình 6. Trong
hình naøy, böôùc xöû lyù caâu leänh SQL vaø truy
xuaát döõ lieäu laø khaù quan troïng. Moät trong
haàu heát nhöõng nhieäm vuï phoå bieán cuûa moät
chöông trình OCI laø chaáp nhaän vaø xöû lyù caâu
leänh SQL, moät khi caùc handle caàn thieát ñaõ
ñöôïc caáp phaùt vaø ñaõ keát noái ñöôïc vôùi
Oracle server. Ñoàng thôøi vôùi moãi böôùc treân,
OCI cung caáp caùc haøm caàn thieát töông öùng
cho xöû lyù caâu leänh SQL, chi tieát coi trong
[6].
4. ÖÙNG DUÏNG
Chuùng toâi ñaõ caøi ñaët thöû nghieäm
nhöõng caâu truy vaán coù yeáu toá thôøi gian treân
moâi tröôøng Visual C++ vôùi döõ lieäu thöïc cuûa
beänh vieän Nhaân daân Gia Ñònh-TP.HCM, vaø
coù nhöõng keát quûa toát.
4.1 Cuù phaùp cuûa caâu truy vaán
SubTSQL
Ñeå thöïc hieän bieân dòch caâu truy vaán
baèng maõ nguoàn môû, phaàn naøy nhaéc laïi moät
soá yù cô baûn veà SubTSQL, chi tieát coù theå
xem trong [9]. Döõ lieäu thôøi gian ñöôïc caäp
nhaät trong nhöõng baûng döõ lieäu cuûa moâ hình
quan heä truyeàn thoáng, trong moãi baûng neáu
coù döõ lieäu thôøi gian thì theâm vaøo 2 coät
v_begin (thôøi gian baét ñaàu cuûa döõ lieäu ñöôïc
sinh ra), vaø v_end (thôøi gian keát thuùc). Noùi
moät caùch khaùc döõ lieäu (hay söï kieän) ñöôïc
ghi trong baûng coù giaù trò ñuùng trong khoaûng
thôøi gian töø v_begin ñeán v_end (xem baûng
patient döôùi ñaây.
Caâu truy vaán thôøi gian SubTSQL
töông töï nhö nhöõng caâu SQL thoâng thöôøng,
chæ theâm moät meänh ñeà WHEN ñeå thao taùc
yeáu toá thôøi gian, yeáu toá thôøi gian laø vò trí
töông ñoái giöõa hai khoaûng thôøi gian v_begin
vaø v_end vaø noù tuaân theo nhöõng taân töø trong
[2], cuï theå laø nhöõng taân töø: BEFORE,
AFTER, DURING, CONTAINS, OVERLAPS,
Khởi tạo tiến trình
Khởi tạo môi trường
Định vị các handle
Kết nối với server
Gửi câu SQL và xử lý
Ngắt kết nối
Giải phóng các handle và cấu trúc dữ liệu
Hình 6: Những bước hoạt động của OCI
Khoa hoïc - kó thuaäät
42
MEETS, STARTS, FINISHES, vaø EQUALS.
Vaø sau ñaây laø moät soá ví duï cuï theå veà caâu truy
vaán thôøi gian.
- Caâu truy vaán SELECT, meänh ñeà
WHEN duøng taân töø ‚DURING‛
SELECT manv, Hoten, V_begin,
V_end FROM NhanVien
WHEN NhanVien DURING
(25/3/2000 , 25/5/2000)
WHERE mapb = 'D8' ;
- Caâu truy vaán UPDATE, meänh ñeà
WHEN chæ ra thôøi gian caàn caäp nhaät
UPDATE drugs set drug= 'dfdsf' WHEN
(25/02/03,05/03/03,'dd/mm/yy')
where p_id>0
- Caâu truy vaán DELETE, meänh ñeà
WHEN chæ ra döõ lieäu caàn xoùa trong moät
khoûang thôøi gian.
DELETE from drugs
WHEN(5/02/03,05/03/03,'dd/mm/yy') where
p_id>0
Ví duï: Cho baûng döõ lieäu Patient vaø
caâu truy vaán thôøi gian nhö sau
Patient
P_ ID problem department v_begin v_end
J001 P1 D10 14/02/2000 01/03/2000
J001 P2 C2 10/03/2000 31/12/9999
P005 P3 D8 01/04/2000 12/05/2000
R006 P3 D8 13/02/2000 01/06/2000
SELECT p_id, problem, v_begin,
v_end
FROM patient
WHEN patient DURING
(25/3/2000 , 25/5/2000)
WHERE department = 'D8' ;
Caâu truy vaán treân caàn bieân dòch
thaønh caâu Oracle-SQL
SELECT p_id, problem, v_begin,
v_end
FROM patient
WHERE department ='D8' AND
((patient.v_begin)>
to_date(‘25/3/2000’,’’dd/mm/yyyy’)
AND( (patient.v_end) <=
to_date(‘25/5/2000’,’dd/mm/yyyy’))
OR (( patient.v_begin) >=
to_date(‘25/3/2000’,’dd/mm/yyyy’))
AND (patient.v_end)<
to_date(‘25/5/2000’,’dd/mm/yyyy’));
Trong ví duï naøy, phaàn chöõ in
nghieâng, ñaäm trong meänh ñeà WHERE cuûa
caâu Oracle-SQL chính laø noäi dung cuûa
meänh ñeà WHEN ñöôïc vieát theo nhöõng taân
töø so saùnh khoaûng thôøi gian nhö trong [2].
Ví duï naøy cho thaáy: moät caâu truy vaán thôøi
gian ñöôïc vieát baèng caâu truy vaán thoâng
thöôøng thì khaù phöùc taïp, raát deã maéc loãi,
ngay caû nhöõng laäp trình vieân chuyeân
nghieäp. Do vaäy, vieäc bieân dòch caâu
SubTSQL baèng maõ nguoàn môû coù yù nghóa
thieát thöïc, cuõng nhö caâu SubTSQL vôùi cuù
phaùp ñôn giaûn, deã thaân thieän vôùi ngöôøi
duøng (Nhöõng caâu truy vaán thôøi gian Update
vaø Delete cuõng ñöôïc bieân dòch moät caùch
töông töï nhö caâu truy vaán Select).
4.2 Kieán truùc trong caøi ñaët
Ñeå thöïc hieän caøi ñaët, chuùng toâi kieán
truùc moät moâ-ñun nhö hình 7, ñaët trong
khung hình chöõ nhaät ñöôïc vieàn ñaäm baèng
ñöôøng keùp, vaø noù ñöôïc ñaët treân ñænh cuûa
HQTCSDL Oracle. Hôn nöõa moâ-ñun naøy,
noù ñoäc laäp vôùi moïi HQTCSDL, neáu ñöôïc
chænh laïi moät chuùt trong Yacc ñeå coù maõ sinh
ra ñuùng vôùi cuù phaùp cuûa HQTCSDL caàn
duøng.
Khoa hoïc - kó thuaäät
43
Trong hình 7, tieán trình thöïc hieän
caâu truy vaán bao goàm : Ngöôøi duøng nhaäp
moät caâu leänh Q, sau ñoù Lex phaân tích Q
thaønh caùc token. Yacc phaân tích cuù phaùp
cuûa Q döïa treân cuù phaùp cuûa SubTSQL. Baát
kì loãi naøo ñöôïc tìm thaáy trong quaù trình
phaân tích seõ thoâng baùo. Neáu khoâng coù loãi
thì Q ñöôïc göûi ñeán Boä sinh maõ, noù bieân
dòch Q thaønh caâu leänh SQL cuûa Oracle, sau
ñoù göûi ñeán heä quaûn trò CSDL Oracle thoâng
qua moâ-ñun OCI, taïi ñaây noù nhaän caâu leänh
SQL- Oracle vaø thöïc hieän treân Oracle ñeå
laáy keát quaû traû veà. Cuoái cuøng Boä xöû lyù xuaát
keát quaû cho ngöôøi duøng.
4.3 Giao dieän thöïc hieän caâu truy vaán
Hình 8 chæ ra maøn hình giao dieän vôùi
ngöôøi duøng ñeå thöïc hieän vaán tin treân CSDL
höôùng thôøi gian, ñöôïc caøi ñaët trong Visual
C++, ngöôøi duøng coù theå soaïn caâu truy vaán
trong khung SubTSQL input, sau ñoù cho keát
noái Oracle baèng nuùt Connect vaø thöïc thi
baèng nuùt Execute, Keát quaû ñöôïc hieän thò
trong Results. Neáu quaù trình bieân dòch hay
thöïc thi treân Oracle coù loãi, thoâng baùo loãi ñöôïc
hieån thò trong SQL output/Error output.
5. KEÁT LUAÄN
Xaây döïng öùng duïng baèng söû duïng
maõ nguoàn môû ñaõ giaûm ñöôïc nhieàu chi phí,
hôn nöõa maõ nguoàn môû cho pheùp coù theå aùp
duïng xaây döïng nhöõng öùng duïng khaùc nhau
trong nhieàu laõnh vöïc. Trong baøi baùo naøy, söû
duïng LEX vaø YACC bieân dòch nhöõng caâu
leänh ñeå thöïc hieän nhöõng öùng duïng trong moâ
hình CSDL höôùng thôøi gian. Vaø coøn coù
nhieàu maõ nguoàn môû khaùc cho pheùp ngöôøi
duøng söû duïng theo yeâu caàu rieâng cuûa moãi
ngöôøi maø khoâng vi phaïm baûn quyeàn, vaø ñi
vaøo khaù nhieàu laõnh vöïc öùng duïng thieát thöïc
nhö: keá toaùn, phaùt trieån Web, chính phuû
ñieän töû, coâng ngheä sinh hoïc, quaûn trò doanh
nghieäp . . . coù theå xem chi tieát trong taäp san
[8]. Trong chieàu höôùng Vieät Nam gia nhaäp
WTO, thì vieäc phaùt trieån veà CNTT duøng maõ
nguoàn môû laø moät loái ñi deã daøng coù nhieàu
höùa heïn. Coâng vieäc tieáp theo cuûa chuùng toâi
tieáp tuïc trieån khai öùng duïng maõ nguoàn môû
ñeå xaây döïng theâm nhöõng caâu truy vaán cho
vieäc trích yeáu thôøi gian trong moâ hình
CSDL höôùng thôøi gian.
Hình 7: Kieán truùc thöïc hieän caâu truy vaán
Oracle
Bộ sinh mã
Bộ xử lý
xuất kết
qủa
Câu truy vấn SubTSQL
Mô-đun OCI
Lex
Yacc
Kết qủa Báo lỗi
Khoa hoïc - kó thuaäät
44
TAØI LIEÄU THAM KHAÛO
[1] Anthony A. Aaby, ‘Compiler
construction using FLex and Bison’, Walla
Walla College, April, 2005.
[2] J.F. Allen, ‘Maintaining
Knowledge about Temporal Intervals’,
Communication of the ACM, 26(11),
November, 1993, 832-843.
[3] C.J. Date, Hugh Darwen,
N.A.Lorentzos, ‘Temporal Data and the
Relation Model’, Morgan Kaufmann
Publishers, 2003.
[4] Bert Hubert, ‘LEX and YACC
primer/How to’, PowerDNS BV, April,
2002.
[5] N. A. Lorentzos, ‘The Interval-
extended Relational Model and its
Application to Valid-time Databases’,
Temporal Databases – Theory, Design and
Implementation, Benjamin/ Cummings
Publishing, 1993, 65-91.
[6] Phil Locke, ‘Oracle Call
Interface Programmer’s Guide’, Oracle
Corporation, 1997.
[7] Thomas Niemann, ‘A compact
guide to LEX & YACC ’,
www.epaperpress.com.
[8] Taäp san ‘Hoäi thaûo khoa hoïc öùng
duïng phaàn meàm maõ nguoàn môû’, Vaên phoøng
CNTT- Boä KH&CN, Sôû KH&CN- TP.HCM
13-09-2005.
[9] Phaïm vaên Chung. Döông Tuaán
Anh, ‚Implementing a Query Sublanguage
for Temporal Clincal database Systems‛,
Proceedings of the MMU International
Symposum on information &
Communications Technologies 2005, 24–
25 November 2005, Malaysia, pp. TS12-
13-16.
Hình 8: Giao dieän thöïc hieän hieän caâu truy vaán coù
yeáu toá thôøi gian
Các file đính kèm theo tài liệu này:
- 3744R.pdf