Tài liệu Đề tài Xây dựng hệ thống thông tin quản lý xuất nhập hàng tại công ty công nghiệp chế biến thực phẩm quốc tế chi nhánh Nha Trang: Lời nói đầu
Ngày nay cùng với sự phát triển nhanh chóng của Công nghệ thông tin và việc ứng dụng nó vào thực tế của các ngành kinh tế và đời sống đem lại những lợi ích vô cùng to lớn. Có thể nói rằng kỹ nguyên của chúng ta là kỹ nguyên của công nghệ thông tin.
Trong đó Bưu Điện, Ngân Hàng, Kinh Doanh là những ngành phát triển các ứng dụng công nghệ tin học hàng đầu. Nhưng thực tế tại CÔNG TY CÔNG NGHIỆP CHẾ BIẾN THỰC PHẨM QUỐC TẾ chi nhánh Nha Trang chưa hoàn toàn tin học hoá trong quản lý kinh doanh. Quản lý xuất nhập hàng hoá là một trong các công tác hoạt động chính của công ty, hiện tại đang cần một hệ thống quản lý mới phù hợp hơn bởi vì hầu hết các chương trình quản ly được xây dựng trên môi trường ACCESS và Pocro nên vẫn còn nhiều hạn chế và chưa đáp ứng được với nhu cầu thực tế.
Qua thời gian tiếp xúc với CÔNG TY CÔNG NGHIỆP CHẾ B...
67 trang |
Chia sẻ: hunglv | Lượt xem: 1571 | Lượt tải: 0
Bạn đang xem trước 20 trang mẫu tài liệu Đề tài Xây dựng hệ thống thông tin quản lý xuất nhập hàng tại công ty công nghiệp chế biến thực phẩm quốc tế chi nhánh Nha Trang, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
Lôøi noùi ñaàu
Ngaøy nay cuøng vôùi söï phaùt trieån nhanh choùng cuûa Coâng ngheä thoâng tin vaø vieäc öùng duïng noù vaøo thöïc teá cuûa caùc ngaønh kinh teá vaø ñôøi soáng ñem laïi nhöõng lôïi ích voâ cuøng to lôùn. Coù theå noùi raèng kyõ nguyeân cuûa chuùng ta laø kyõ nguyeân cuûa coâng ngheä thoâng tin.
Trong ñoù Böu Ñieän, Ngaân Haøng, Kinh Doanh laø nhöõng ngaønh phaùt trieån caùc öùng duïng coâng ngheä tin hoïc haøng ñaàu. Nhöng thöïc teá taïi COÂNG TY COÂNG NGHIEÄP CHEÁ BIEÁN THÖÏC PHAÅM QUOÁC TEÁ chi nhaùnh Nha Trang chöa hoaøn toaøn tin hoïc hoaù trong quaûn lyù kinh doanh. Quaûn lyù xuaát nhaäp haøng hoaù laø moät trong caùc coâng taùc hoaït ñoäng chính cuûa coâng ty, hieän taïi ñang caàn moät heä thoáng quaûn lyù môùi phuø hôïp hôn bôûi vì haàu heát caùc chöông trình quaûn ly ñöôïc xaây döïng treân moâi tröôøng ACCESS vaø Pocro neân vaãn coøn nhieàu haïn cheá vaø chöa ñaùp öùng ñöôïc vôùi nhu caàu thöïc teá.
Qua thôøi gian tieáp xuùc vôùi COÂNG TY COÂNG NGHIEÄP CHEÁ BEÁN THÖÏC PHAÅM QUOÁC TEÁ chi nhaùnh Nha Trang toâi ñöôïc caùc coâ chuù vaø anh chò trong coâng ty gôïi yù vaø giuùp ñôõ, toâi ñaõ quyeát ñònh choïn ñeà taøi “Xaây döïng heä thoáng thoâng tin quaûn lyù xuaát nhaäp haøng” laøm ñeà taøi thöïc taäp toát nghieäp cuûa mình.
Vôùi ñeà taøi naøy toâi chia thaønh 5 chöông nhö sau:
Chöông I : Khaûo saùt & phaân tích hieän traïng
Chöông II : Giôùi thieäu caùc coâng ngheä lieân quan
Chöông III : Phaân tích vaø thieát keá heä thoáng
Chöông IV: Xaây döïng chöông trình
Chöông V: Ñaùnh giaù heä thoáng
Do thôøi gian haïn cheá vaø kieán thöùc coùn haïn heïp neân trong ñeà taøi naøy khoâng theå traùnh khoûi nhöõng thieáu soùt. Kính mong quyù thaày coâ giaùo vaø caùc baïn sinh vieân ñoùng gôùp yù kieán ñeå cho ñeà taøi naøy ngaøy caøng hoaøn thieän hôn.
Nhaân ñaây em xin chaân thaønh caûm ôn coâ Buøi Thò Hoaø– GV boä moân Coâng Ngheä Phaàn Meàm – khoa Coâng Ngheä Thoâng Tin tröôøng ÑHBK Haø Noäi ñaõ taän tình höôùng daãn em trong quaù trình thöïc hieän ñeà taøi thöïc taäp toát nghieäp naøy.
Haø Noäi 7 – 2003
Sinh vieân thöïc hieän:
Ñinh Troïng Vinh
MUÏC LUÏC
LÔØI NOÙI ÑAÀU …………………………………………………………..…… 1
MUÏC LUÏC …………………………………………………………………… 2
Chöông 1: KHAÛO SAÙT VAØ PHAÂN TÍCH HIEÄN TRAÏNG ………………… 3
I. Giôùi thieäu veà Coâng ty………………………………………………… 3
II. Phaân tích hieän traïng …………………………………………………… 4
Chöông 2: PHAÂN TÍCH VAØ THIEÁT KEÁ HEÄ THOÁNG …………………… 8
I. Moâ hình quan nieäm döõ lieäu …………………………………………… 8
II. Moâ hình toå chöùc döõ lieäu ……………………………………………… 8
III. Moâ hình vaät lyù döõ lieäu ………………………………………………… 9
IV. Moâ hình thoâng löôïng ………………………………………………… 14
V. Moâ hình quan nieäm xöû lyù ………………………………………………16
VI. Moâ hình toå chöùc xöû lyù ……………………………………………… 18
VII. Moâ hình vaät lyù xöû lyù ………………………………………………… 22
Chöông 3: GIÔÙI THIEÄU CAÙC COÂNG NGHEÄ LIEÂN QUAN ……………… 23
I. Giôùi thieäu veà Visual Basic 6.0 ………………………………………… 23
II. Laøm vieäc vôùi Microsoft Visual Basic 6.0 …………………………… 24
III. Khaû naêng keát noái vôùi cô sôû döõ lieäu cuûa Visual Basic ………………… 31
Chöông 4: XAÂY DÖÏNG CHÖÔNG TRÌNH ……………………………… 33
I. Phaàn döõ lieäu……………………………………………………………… 33
II. Moät soá giao dieän chính ………………………………………………… 34
III. Moät soá Module chính ………………………………………………… 36
Chöông 5: ÑAÙNH GIAÙ HEÄ THOÁNG …..………………………………… 39
TAØI LIEÄU THAM KHAÛO ………………………………………………… 40
CHÖÔNG I
KHAÛO SAÙT VAØ PHAÂN TÍCH HIEÄN TRAÏNG
I. KHAÛO SAÙT HIEÄN TRAÏNG
1. Giôùi thieäu toång quaùt
Hieän nay, Ngaønh quaûn lyù kinh doanh noùi chung vaø Coâng ty coâng nghieäp cheá bieán thöïc phaåm quoác teá – Chi nhaùnh Nha Trang noùi rieâng, vaán ñeà aùp duïng coâng ngheä tin hoïc ñang ñöôïc ñaët leân haøng ñaàu nhaèm hoaøn chænh hoaù heä thoáng giao dòch vaø quaûn lyù haøng cuûa coâng ty, nhaèm taêng khaû naêng hoaït ñoäng, giaûm bôùt soá löôïng nhaân vieân quaûn lyù, ñaûm baûo ñoä chính xaùc vaø khaû naêng baûo maät, an toaøn döõ lieäu cao. Vì nhöõng lyù do ñoù cho neân vieäc thay theá vaø naâng caáp heä thoáng quaûn lyù kinh doanh môùi ñang laø vaán ñeà caáp baùch cho ngaønh kinh doanh.
Coâng ty coâng nghieäp cheá bieán thöïc phaåm quoác teá – Chi nhaùnh Nha Trang hieän nay ñang söû duïng heä thoáng quaûn lyù kinh doanh do toång coâng ty ñöa ra cho caùc chi nhaùnh. Heä thoáng naøy chaïy treân neàn heä heä quaûn trò CSDL Access vaø Foxpro.
Heä thoáng treân nhìn chung coù nhieàu öu ñieåm veà tính ñoàng nhaát, chaïy nhanh, kích thöôùc döõ lieäu nhoû vaø khoâng ñoøi hoûi caáu hình cuûa maùy tính cao, caùi maø nhöõng naêm tröôùc ñaây coøn laø vaán ñeà khoù khaên cho ngaønh kinh teá. Nhöng hieän nay vieäc ñaàu tö cô sôû vaät chaát cho heä thoáng thoâng tin quaûn lyù kinh doanh khoâng coøn laø vaán ñeà khoù khaên haøng ñaàu nöõa, maø vaán ñeà ñaët ra laø tính chính xaùc, nhanh, an toaøn vaø ñoä baûo maät cuõng nhö khaû naêng quaûn lyù toaøn dieän ñeå taêng tính caïnh tranh vaø giaûm bôùt nhaân söï ñang laø vaán ñeà môùi cho moïi ngaønh quaûn lyù.
Quaûn lyù xuaát/ nhaäp haøng laø moät trong caùc hoaït ñoäng chính cuûa coâng ty. Heä thoáng quaûn lyù haøng hoaù vaø coâng nôï ñöôïc tích hôïp chung trong heä thoáng thoâng tin quaûn lyù kinh doanh cuûa coâng ty.
Tuy coù nhöõng tính naêng vaø öu ñieåm nhö ñaõ trình baøy ôû treân nhöng noù cuõng coøn nhieàu haïn cheá nhö chaïy chaäm khi khoái löôïng döõ lieäu lôùn, khaû naêng quaûn lyù khoái löôïng döõ lieäu coøn haïn cheá, khaû naêng baûo maät chöa cao, giao dieän chöa thaân thieän vôùi ngöôøi söû duïng.
2. Hieän traïng quaûn lyù kinh doanh ôû coâng ty
Qua quaù trình khaûo saùt vaø tìm hieåu thöïc teá quy trình quaûn lyù kinh doanh ôû Coâng ty, toâi naém ñöôïc moät soá hieän traïng cuûa Coâng ty nhö sau:
Coâng ty coâng nghieäp cheá bieán thöïc phaåm quoác teá –Chi nhaùnh Nha Trang laø moät chi nhaùnh cuûa toång Coâng ty ôû Malaysia. Toång Coâng ty chuyeân saûn xuaát caùc maët haøng thöïc phaåm – Caùc loaïi nöôùc traùi ñoùng lon vaø baùnh keïo caùc loaïi(Nöôùc bí, nöôùc yeán, keïo xoáp, …). Chi nhaùnh Nha Trang chòu traùch nhieäm phaân phoái caùc saûn phaåm cuûa toång Coâng ty saûn xuaát cho caùc tænh ôû khu vuïc 8 tænh mieàn trung (Khaùnh Hoaø, Ninh Thuaän, Phuù Yeân, Bình Ñònh, Gia Lai, KonTum, Ñak Lak).
2.1. Sô ñoà hoaït ñoäng kinh doanh cuûa chi nhaùnh Coâng ty
TOÅNG COÂNG TY
CAÙC CHI NHAÙNH
CAÙC SHOP
CAÙC ÑAÏI LYÙ
CC haøng
PP haøng
PP haøng
Chöùc naêng cuûa töøng thaønh phaàn trong sô ñoà.
Toång coâng ty: toång coâng ty chuyeân saûn xuaát caùc maët haøng thöïc phaåm (caùc loaïi nöôùc uoáng ñoùng lon vaø caùc loaïi baùnh keïo) vaø cung caáp caùc saûn phaåm naøy cho caùc chi nhaùnh cuûa coâng ty.
Caùc chi nhaùnh cuûa coâng ty chòu traùch nhieäm phaân phoái caùc saûn phaåm tôùi caùc cöûa haøng (Shop) vaø caùc ñaïi lyù.
2.2. Sô ñoà toå chöùc cuûa chi nhaùnh Coâng ty
BAN GIAÙM ÑOÁC
BOÄ PHAÄN KINH DOANH
BOÄ PHAÄN KEÁ TOAÙN
BOÄ PHAÄN KHO
Vai troø vaø chöùc naêng cuûa caùc boä phaän trong coâng ty laø :
Ban Giaùm ñoác chi nhaùnh : Ñieàu haønh hoaït ñoäng Coâng ty.
Boä phaän keá toaùn: Keát toaùn soå saùch.
Boä phaän kinh doanh : Tìm hieåu thò tröôøng, ñöa ra caùc chieán löôïc kinh doanh, giôùi thieäu saûn phaåm.
Boä phaän kho: Löu tröù haøng hoaù vaø baûo quaûn haøng hoùa, baùo caùo tình hình soá löôïng haøng hoaù trong kho.
3. Caùc quy trình quaûn lyù nhö sau
a. Quy trình quaûn lyù nhaäp haøng
Boä phaän kinh doanh caên cöù vaøo nhu caàu mua haøng cuûa khaùch haøng, soá löôïng haøng hoaù toàn toái thieåu, soá löôïng haøng hoaù toàn toái ña trong kho vaø danh saùch caùc maët haøng hieän coù cuûa toång coâng ty ñeå laäp ñôn ñaët haøng. Trong ñôn ñaët haøng coù ñaày ñuû thoâng tin veà chi nhaùnh coâng ty, danh saùch vaø soá löôïng caùc maët haøng caàn nhaäp veà.
Boä phaän kinh doanh seõ trình ñôn ñaët haøng leân ban giaùm ñoác kyù duyeät.
Neáu ñôn ñaët haøng ñaõ ñöôïc ban giaùm ñoác kyù duyeät thì boä phaän kinh doanh seõ göûi ñôn ñaët haøng tôùi toång coâng ty.
Neáu ñöôïc toång coâng ty chaáp thuaän cung caáp haøng thì boä phaän kinh doanh seõ laäp phieáu nhaäp haøng vaø nhaän haøng ñöa veà kho.
Moãi laàn nhaäp haøng ñeàu phaûi laøm moät phieáu nhaäp bao goàm: Thoâng tin ñaày ñuû veà nhaø cung caáp, danh saùch caùc maët haøng, soá löôïng, ngaøy nhaäp, ñôn giaù, ngaøy heïn traû tieàn theo maãu ñaõ ñöôïc in saün.
Boä phaän kinh doanh seõ chuyeån phieáu nhaäp haøng vaø phieáu thanh toaùn tôùi boä phaän keá toaùn ñeå thanh toaùn tieàn haøng cho toång coâng ty.
Caùch tính toång giaù trò haøng nhaäp:
Toång giaù trò = soá löôïng nhaäp * ñôn giaù nhaäp
Moãi laàn nhaäp haøng veà thì phaûi tieán haønh caäp nhaät laïi danh muïc haøng hoaù nhö laø theâm maët haøng (neáu ñoù laø maët haøng môùi), caäp nhaät laïi soá löôïng, tính laïi ñôn giaù (baèng phöông phaùp tính ñôn giaù bình quaân gia quyeàn).
Trong ñoù:
Dgbqck: ñôn giaù bình quaân cuoái kyø.
Tgtondk: toång giaù toàn ñaàu kyø.
Tgnhaptk: toång giaù nhaäp trong kyø.
Sltondk: soá löôïng toàn ñaàu kyø.
Slnhaptk: soá löôïng nhaäp trong kyø.
b. Quy trình quaûn lyù xuaát haøng
Khi moät khaùch haøng caàn mua haøng thì laøm moät ñôn ñaët haøng theo maãu in saün bao goàm : Phaàn ñaàu goàm nhöõng thoâng tin ñaày ñuû veà khaùch haøng, phaàn thöù hai laø danh saùch maët haøng ñaët mua, soá löôïng, ñôn giaù töøng loaïi vaø ngaøy nhaän haøng. Khi ñaët haøng, coù theå khaùch haøng ñaët moät soá tieàn naøo ñoù.
Khi mua haøng, khaùch haøng coù theå traû tieàn tröôùc hay heïn traû sau khi nhaän haøng moät soá ngaøy quy ñònh.
Ñôn ñaët haøng ñöôïc ñöa ñeán boä phaän kinh doanh ñeå xem xeùt. Neáu khaùch haøng coøn nôï treã haïn quaù moät soá tieàn quy ñònh thì boä phaän kinh doanh töø choái baùn haøng. Neáu haøng toàn kho ñuû thì cung caáp cho khaùch haøng theo ñôn ñaët haøng.
Haøng ngaøy boä phaän kinh doanh xem xeùt caùc ñôn ñaët haøng ñoàng thôøi so saùnh toàn kho, ñeå laøm giaáy baùo cho khaùch haøng nhaän haøng, giaáy baùo nôï cho khaùch haøng vaø ñaët haøng cho nhaø cung caáp khi löôïng haøng toàn vöôït döôùi möùc toàn toái thieåu.
Moãi laàn xuaát haøng ñeàu phaûi laøm moät phieáu xuaát bao goàm : Thoâng tin ñaáy ñuû veà khaùch haøng, danh saùch maët haøng, soá löôïng, ngaøy nhaäp xuaát, ñôn giaù, ngaøy heïn traû tieàn.
Caùch tính toång giaù trò haøng xuaát:
Toång giaù trò = soá löôïng xuaát * ñôn giaù xuaát
c. Thoáng keâ.
Ñònh kyø haøng thaùng phaûi baùo caùo xuaát, nhaäp toàn haøng hoaù trong thaùng theo maãu ñaõ ñònh.
Soá löôïng haøng toàn = soá löôïng haøng nhaäp – soá löôïng haøng xuaát
Taïi baát kyø thôøi ñieåm naøo, neáu ñöôïc yeâu caàu cuûa ngöôøi coù thaåm quyeàn thì phaûi baùo caùo tình hình haøng hoaù cuûa töøng loaïi, töøng kho, tình hình coâng nôï.
4. Moät soá maãu ñôn töø ñöôïc söû duïng trong quaù trình hoaït ñoäng kinh doanh
a. Maãu phieáu ñaët haøng
Maãu phieáu ñaët haøng naøy duøng chung cho caû coâng ty ñaët mua haøng vaø khaùch ñaët haøng.
COÂNG TY CN CB THÖÏC PHAÅM QUOÁC TEÁ
CHI NHAÙNH THAØNH PHOÁ NHA TRANG
Ñieän thoaïi: 834223 Fax: 834225
E-mail:
PHIEÁU ÑAËT HAØNG
(Khoâng coù giaù trò thanh toaùn)
INTERFOOD PROCESSING INDUSTRY LTD.
NHA TRANG BRANCH
Hoï vaø teân khaùch haøng: …………………………………………………… Tel: ………….
Ñòa chæ: …………… Ñöôøng: ………………… Phöôøng: ……………… Quaän: …………
MS thueá: …………….. Giao haøng: ……………giôø, ngaøy …… thaùng………naêm………
Ngöôøi nhaän ñaët haøng: ……………………………………………… Ñaët haøng TEL:
STT
MAËT HAØNG
SOÁ LÖÔÏNG
ÑÔN GIAÙ
THAØNH TIEÀN
1
2
3
4
5
6
7
8
9
10
TOÅNG COÄNG
LÖU YÙ:
* Phöông thöùc thanh toaùn: Tieàn maët: Traû chaäm: ………………………ngaøy.
Traû tieàn phieáu tröôùc môùi nhaän giao haøng phieáu sau.
Phaûi kieåm tra soá löôïng, chaát löôïng haøng khi nhaän. Chæ nhaän ñoåi laïi haøng moùp, raùch
bao bì, xì nöôùc … Trong voøng 03 ngaøy.
* Coâng nôï cuõ cuûa khaùch haøng soá HDD: …………… ngaøy mua haøng ………Trò giaù………
……………………………………………………………………………………………………………………………………………………………………………………………………
Ngaøy ………… thaùng …… naêm ……
GÑ DUYEÄT TRÖÔÛNG PHOØNG GIAÙM SAÙT TT NHAÂN VIEÂN TT
KD – TT Kieåm tra Ñaët haøng
b. Maãu phieáu nhaäp kho
Ñôn vò : …………………
Ñòa chæ : …………………
PHIEÁU NHAÄP KHO
Soá ……
Ngaøy … thaùng …. Naêm …….
Maãu soá : 01 – VT
Ban haønh theo QÑ soá : 1141 – TC/QÑ/CÑKT
Ngaøy 1 thaùng 11 naêm 1995
Cuûa Boä Taøi Chính
- Hoï vaø teân ngöôøi giao haøng: ……………………………………………………………
- Theo …………………… soá……………… ngaøy ……… thaùng…………naêm……
Cuûa ………………………………………………………………………………………
Nhaäp taïi kho : ……………………………………………………………………………
STT
TEÂN, NHAÕN HIEÄU, QUY CAÙCH, PHAÅM CHAÁT VAÄT TÖ
(SAÛN PHAÅM, HAØNG HOAÙ)
Maõ soá
Ñôn vò tính
SOÁ LÖÔÏNG
Ñôn giaù
Thaønh tieàn
Theo chöùng töø
Thöïc nhaäp
A
B
C
D
1
2
3
4
COÄNG
x
x
x
x
x
ngaøy …… thaùng …… naêm ….
THUÛ TRÖÔÛNG ÑÔN VÒ NGÖÔØI NHAÄN NGÖÔØI GIAO NGÖÔØI LAÄP PHIEÁU
c. Maãu phieáu xuaát kho
Ñôn vò : …………………
Ñòa chæ : …...……………
PHIEÁU XUAÁT KHO
Ngaøy … thaùng …. Naêm …….
Soá : …………
Nôï:………………………...
Coù: …..……………………
Hoï vaø teân ngöôøi nhaän haøng: ……………………………………………………………
Ñòa chæ (boä phaän): ………………………………………………………………………
Lyù do xuaát kho: …………………………………………………………………………
Xuaát taïi kho: ……………………………………………………………………………
STT
TEÂN, NHAÕN HIEÄU, QUY CAÙCH, PHAÅM CHAÁT VAÄT TÖ
(Saûn phaåm haøng hoaù)
Maõ soá
Ñôn vò tính
SOÁ LÖÔÏNG
Ñôn giaù
Thaønh tieàn
Yeâu caàu
Thöïc xuaát
A
B
C
D
1
2
3
4
COÄNG:
Toång soá tieàn (Vieát baèng chöõ): ………………………………………………………
Xuaát, ngaøy …… thaùng …… naêm ……
Phuï traùch boä phaän Phuï traùch keá toaùn Ngöôøi nhaän Thuû kho
d. Maãu phieáu ñeà nghò thanh toaùn
Maãu phieáu naøy duøng chung cho caû coâng ty vaø khaùch mua hang.
OFFICIAL RECEIPT
PHIEÁU THU
Date: ……/ …… / ………
CREDIT
TAØI KHOAÛN GHI COÙ …………………
RECEIVED FORM M/S
Nhaän cuûa ……………………………………………..…………………………………..
POST
Boä phaän coâng taùc …………………………………………………………………………
BEING
Veà khoaûn: …………………………………………………………………………………
…………………………………………………………………………………………….
AMOUNT (IN WORDS)
Soá tieàn …………………..………………… ñoàng (baèng chöõ) …………………………..
…………………………………………………………………………………………….
ENCLOSE DOCUMENTS
Keøm theo ……………………………………………………. Chöùng töø goác
Date: ……../ ………../ …………
THUÛ TRÖÔÛNG ÑÔN VÒ KEÁ TOAÙN TRÖÔÛNG KT THANH TOAÙN THUÛ QUYÕ NGÖÔØI NOÄP
MANAGER CHIEF ACCOUNT ACCOUNTANT CASHIER ACKNOWLEDGET BY
INTERFOOD PROCESSING INDUSTRY LTD
COÂNG TY COÂNG NGHIEÄP CHEÁ BIEÁN THÖÏC PHAÅM QUOÁC TEÁ
NHA TRANG BRANCH
CHI NHAÙNH TP.NHA TRANG
MST: 360024563.1.004.1
No
Soá …… Maãu soá 3 - TM
II. PHAÂN TÍCH VAØ LAÄP DÖÏ AÙN
1. Phaân tích
Qua thöïc teá khaûo saùt, ta caàn quaûn lyù caùc ñoái töôïng chính trong heä thoáng quaûn lyù xuaát nhaäp haøng nhö sau: Khaùch haøng (bao goàm caû nhaø cung caáp vaø khaùch mua hang), Haøng hoaù, Kho.
a. Quaûn lyù khaùch haøng: Moïi khaùch haøng cuûa Coâng ty (bao goàm caû nhaø cung caáp vaø khaùch mua haøng) ñeàu ñöôïc Coâng ty quaûn lyù nhöõng thoâng tin chính sau:
Hoï khaùch haøng
Teân khaùch haøng
Teân giao dòch
Ñòa chæ
Soá ñieän thoaïi
Soá fax
Soá taøi khoaûn ngaân haøng
Trong ñoù ñòa chæ khaùch haøng bao goàm:
+ Soá nhaø
+ Ñöôøng
+ Huyeän
+ Tænh
+ Thaønh phoá
+ Quoác gia
b. Quaûn lyù haøng hoaù: Moãi maët haøng ñöôïc quaûn lyù caùc thoâng tin sau:
Teân maët haøng
Nhoùm haøng
Nôi saûn xuaát (haõng saûn xuaát, nöôùc saûn xuaát)
Ñôn vò tính
Soá löôïng toàn toái thieåu
Soá löôïng toàn toái ña
c. Quaûn lyù kho: Haøng hoaù ñöôïc caát giöõ taïi nhieàu kho, moãi kho ñöôïc quaûn lyù caùc thoâng tin sau:
Teân kho
Ñòa chæ kho
Ñieän thoaïi kho
Soá fax
Thuû kho
2. Laäp döï aùn
Qua quaù trình khaûo saùt thöïc teá cuõng nhö phaân tích kyõ yeâu caàu thieát yeáu, toâi ñöa ra moâ hình heä thoáng quaûn lyù xuaát nhaäp haøng nhö sau:
Caàn thieát nhaát laø heä thoáng phaûi quaûn lyù ñöôïc ñaày ñuû thoâng tin veà khaùch haøng, haøng hoaù, kho, caùc hoaù ñôn chöùng töø, cuõng nhö khaû naêng tính toaùn, choïn loïc thoáng keâ vaø in aán caùc thoâng tin.
Phaûi ñaûm baûo ñoä chính xaùc, an toaøn vaø tin caäy cao.
3. Döõ lieäu vaøo, döõ lieäu ra vaø caùc chöùc naêng xöû lyù cuûa heä thoáng
Döõ lieäu vaøo:
Caùc thoâng tin veà khaùch haøng nhö: hoï vaø teân, teân giao dòch, soá nhaø, ñieän thoaïi, fax, taøi khoaûn ngaân haøng, soá tieàn nôï coù theå.
Caùc thoâng tin veà haøng hoaù: teân maët haøng, nhoùm maët haøng, nôi saûn xuaát (haõng saûn xuaát, nöôùc saûn xuaát), ñôn vò tính, soá löôïng toàn toái thieåu, soá löôïng toàn toái ña.
Thoâng tin veà kho haøng: teân kho, ñòa chæ, ñieän thoaïi, fax, thuû kho.
Döõ lieäu ra:
Ñöa ra danh saùch chi tieát veà khaùch haøng
Danh saùch chi tieát veà caùc maët haøng
Danh saùch chi tieát veà caùc kho haøng
In ra danh saùch caùc ñôn ñaët haøng.
In ra danh saùch caùc phieáu xuaát/ nhaäp haøng.
In ra caùc phieáu thanh toaùn.
Thoáng keâ toång soá löôïng haøng nhaäp, toång soá löôïng haøng xuaát trong kyø vaø soá löôïng haøng toàn ton cuoái kyø.
Cho pheùp xuaát döõ lieäu ra maùy in hoaëc maøn hình töøng haïn muïc yeâu caàu. In aán caùc hoaù ñôn chöùng töø.
Chöùc naêng trung taâm:
Xöû lyù, löu tröõ ñôn ñaët haøng, phieáu xuaát nhaäp haøng, phieáu thanh toaùn vaø tính toaùn giaù trò haøng hoaù.
Löu tröõ vaø baûo maät döõ lieäu quaûn lyù hoaù ñôn chöùng töø lieân quan ñeán vieäc xuaát/ nhaäp haøng, haøng hoaù, kho haøng vaø khaùch haøng.
Chöùc naêng cuûa nhaø quaûn lyù nhö:
+ Laäp ñôn ñaët haøng,
+ Laäp phieáu xuaát/ nhaäp haøng,
+ Laäp phieáu thanh toaùn,
+ Laäp baùo caùo veà tình hình hoaït ñoäng kinh doanh.
CHÖÔNG II
PHAÂN TÍCH VAØø THIEÁT KEÁ HEÄ THOÁNG
I. HEÄ THOÁNG THOÂNG TIN
Heä thoáng laø moät taäp hôïp coù quan heä, töông taùc qua laïi vôùi nhau hình thaønh neân moät theå thoáng nhaát.
Heä thoáng kinh doanh vaø heä thoáng dòch vuï: laø nhöõng heä thoáng cuûa con ngöôøi nhaèm muïc ñích kinh doanh hay dòch vuï. Caùc heä thoáng con cuûa heä thoáng kinh doanh – dòch vuï bao goàm 3 heä thoáng nhö sau:
Heä thoáng nghieäp vuï: bao goàm ngöôøi, phöông tieän, phöông phaùp tröïc tieáp tham gia vaøo quaù trình bieán ñoåi luoàng vaøo thaønh luoàng ra.
Heä thoáng quyeát ñònh: bao goàm ngöôøi, phöông tieän, phöông phaùp tham gia vaøo vieäc ñeà xuaát caùc quyeát ñònh.
Heä thoáng thoâng tin: bao goàm ngöôøi, phöông tieän, phöông phaùp tham gia vaøo vieäc xöû lyù caùc thoâng tin.
Vai troø vaø nhieäm vuï cuûa heä thoáng thoâng tin:
Heä thoáng thoâng tin ñoùng vai troø trung gian giöõa beân trong vaø beân ngoaøi heä thoáng vaø nhöõng heä thoáng con.
Nhieäm vuï cuûa heä thoáng thoâng tin: nhaèm thu thaäp, löu tröõ, kieåm tra, keát xuaát, truyeàn ñaït thoâng tin.
II. TOÅNG QUAN VEÀ HEÄ THOÁNG THOÂNG TIN
Heä thoáng thoâng tin giao dòch xuaát nhaäp haøng laø moät heä thoáng thoâng tin hoaït ñoäng vôùi söï trôï giuùp cuûa tin hoïc nhaèm quaûn lyù vaø thöïc hieän caùc giao dòch xuaát nhaäp. Ñaàu vaøo cuûa heä thoáng laø thoâng tin chi tieát veà teân, giaù caû, soá löôïng caùc danh muïc haøng hoaù xuaát – nhaäp, toàn kho, caùc toång keát veà quaù trình giao dòch xuaát nhaäp.
1. Caùc ñoái töôïng yeâu caàu quaûn lyù
Qua quaù trình khaûo saùt thöïc teá, ta caàn quaûn lyù caùc ñoái töôïng chính trong heä thoáng quaûn lyù xuaát nhaäp haøng nhö sau: Khaùch haøng (bao goàm caû nhaø cung caáp vaø khaùch mua haøng), Haøng hoaù, Kho, Ñôn ñaët haøng, Phieáu nhaäp/ xuaát haøng, phieáu thanh toaùn.
a. Quaûn lyù khaùch haøng: Moïi khaùch haøng cuûa Coâng ty (bao goàm caû nhaø cung caáp vaø khaùch mua haøng) ñeàu ñöôïc Coâng ty quaûn lyù nhöõng thoâng tin chính sau:
Maõ khaùch haøng
Hoï khaùch haøng
Teân khaùch haøng
Teân giao dòch
Ñòa chæ
Soá ñieän thoaïi
Soá fax
Soá taøi khoaûn ngaân haøng
Trong ñoù ñòa chæ khaùch haøng bao goàm:
+ Soá nhaø
+ Ñöôøng
+ Huyeän
+ Tænh
+ Thaønh phoá
+ Quoác gia
b. Quaûn lyù haøng hoaù: Moãi maët haøng ñöôïc quaûn lyù caùc thoâng tin sau:
Maõ maët haøng
Teân maët haøng
Nhoùm haøng
Nôi saûn xuaát (haõng saûn xuaát, nöôùc saûn xuaát)
Ñôn vò tính
Soá löôïng toàn toái thieåu
Soá löôïng toàn toái ña
c. Quaûn lyù kho: Haøng hoaù ñöôïc caát giöõ taïi nhieàu kho, moãi kho ñöôïc quaûn lyù caùc thoâng tin sau:
Maõ kho
Teân kho
Ñòa chæ kho
Ñieän thoaïi kho
Soá fax
Thuû kho
d. Quaûn lyù ñôn ñaët haøng:
Maõ ñôn ñaët haøng
Soá löôïng ñaët haøng
Ñôn giaù ñaët haøng
Ngaøy giao
e. Quaûn lyù phieáu nhaäp xuaát haøng: (caû phieáu nhaäp vaø xuaát haøng)
Maø phieáu nhaäp xuaát haøng
Soá löôïng nhaäp xuaát haøng
Ñôn giaù nhaäp xuaát haøng
Ngaøy nhaäp xuaát haøng
Ngaøy heïn traû tieàn
f. Quaûn lyù phieáu thanh toaùn:
Maõ phieáu thanh toaùn
Ngaøy thanh toaùn
Soá tieàn
g. Quaûn lyù ngaân haøng:
Maõ ngaân haøng
Teân ngaân haøng
2. Caùc chöùc naêng cuûa heä thoáng
Quaûn lyù nhaäp haøng: quaûn lyù caùc thoâng tin veà nhaäp haøng hoaù
Thoâng tin vaøo: caùc thoâng tin cô baûn veà maët haøng caàn nhaäp (maõ haøng, teân haøng, soá löôïng, giaù nhaäp, nhaø cung caáp).
Thoâng tin ra: danh muïc haøng caàn nhaäp.
quaûn lyù xuaát haøng: quaûn lyù caùc thoâng tin lieân quan trong coâng taùc xuaát haøng cuûa Coâng ty.
Thoâng tin vaøo: caùc thoâng tin cô baûn khaùch haøng yeâu caàu, thoâng tin veà haøng hoaù, thoâng tin veà kho haøng.
Thoâng tin ra: danh muïc haøng xuaát kho, phieáu xuaát haøng.
Thoáng keâ: thoáng keâ vaø baùo caùo veà hoaït ñoäng giao dòch kinh doanh.
Thoâng tin vaøo: caùc yeâu caàu thoáng keâ.
Thoâng tin ra: baùo caùo thoáng keâ.
Tìm kieám: tìm kieám caùc thoâng tin lieân quan ñeán hoaït ñoäng nhaäp, xuaát haøng hoaù.
Thoâng tin vaøo: caùc yeâu caàu tìm kieám.
Thoâng tin ra: caùc keát quaû tìm kieám.
Qua treân ta thaáy ñöôïc caùc chöùc naêng chuû yeáu cuûa moät heä thoáng thoâng tin giao dòch xuaát nhaäp haøng hoaù. Caùc chöùc naêng naøy ñöôïc chia nhoû ra vaø ñöôïc trình baøy trong sô ñoà phaân raõ chöùc naêng döôùi ñaây, ñeå cho ta hình dung heä thoáng moät caùch chi tieát hôn.
III. SÔ ÑOÀ PHAÂN RAÕ CHÖÙC NAÊNG (BPC) CUÛA HEÄ THOÁNG
1. Sô ñoà phaân raõ toång theå
HOAÏT ÑOÄNG GIAO DÒCH XUAÁT NHAÄP HAØNG
QUAÛN LYÙ XUAÁT HAØNG
THOÁNG KEÂ VAØ BAÙO CAÙO
TÌM KIEÁM
QUAÛN LYÙ NHAÄP HAØNG
2. Sô ñoà chöùc naêng chi tieát.
a. Chöùc naêng quaûn lyù nhaäp haøng.
QUAÛN LYÙ NHAÄP HAØNG
GHI NHAÄN NHAØ CUNG CAÁP MÔÙI
LAÄP ÑÔN ÑAËT HAØNG
LAÄP PHIEÁU NHAÄP HAØNG
THANH TOAÙN
CHOÏN NHAØ CUNG CAÁP THÍCH HÔÏP
KHÔÙP VÔÙI ÑÔN HAØNG VEÀ
CAÄP NHAÄT DANH MUÏC HAØNG
Giaûi thích caùc chöùc naêng:
Choïn nhaø cung caáp môùi: Khi coâng ty muoán nhaäp haøng thì tröôùc heát phaûi choïn nhaø cung caáp thích hôïp ñeå laøm ñoái taùc, tieâu chí choïn nhaø cung caáp ñöôïc döïa treân caùc thoâng tin veà nhaø cung caáp vaø caùc maët haøng maø nhaø cung caáp ñoù coù khaû naêng cung öùng.
Ghi nhaän nhaø cung caáp môùi: Khi nhaø cung caáp naøo ñoù ñöôïc choïn laøm ñoái taùc thì seõ löu laïi caùc thoâng tin veà nhaø cung caáp (Hoï teân nhaø cung caáp, ñòa chæ, ñieän thoaïi, …).
Laäp ñôn ñaët haøng: Khi ñaõ choïn nhaø cung caáp naøo ñoù laøm ñoái taùc roài thì boä phaän kinh doanh seõ tieán haønh laäp ñôn ñaët haøng ñeå göûi tôùi nhaø cung caáp ñaët mua haøng.
Laäp phieáu nhaäp haøng: Khi ñaõ ñöôïc nhaø cung caáp thoaû thuaän cung öùng haøng hoaù thì boä phaän kinh doanh seõ tieán haønh laäp phieáu nhaäp haøng vaø nhaän haøng veà coâng ty.
Caäp nhaät danh muïc haøng: Moãi khi nhaäp haøng veà thì tieán haønh caäp nhaät laïi danh muïc haøng nhö laø Teân maët haøng (neáu laø maët haøng môùi), soá löôïng, …
Khôùp vôùi ñôn haøng veà: Tieán haønh so saùnh caùc hoaù ñôn chöùng töø vôùi löôïng haøng nhaän veà xem ñaõ ñuû soá löôïng, ñuùng maët haøng nhö yeâu caàu hay chöa.
Thanh toaùn: Sau khi khôùp vôùi ñôn haøng veà xong maø khoâng sai soùt gì thì baét ñaàu laäp phieáu thanh toaùn, tieán haønh vieäc thanh toaùn tieàn haøng cho nhaø cung caáp.
b. Chöùc naêng quaûn lyù xuaát haøng.
QUAÛN LYÙ XUAÁT HAØNG
GHI NHAÄN KHAÙCH HAØNG MÔÙI
GIAÛI QUYEÁT ÑÔN ÑAËT HAØNG
LAÄP PHIEÁU XUAÁT HAØNG
CAÄP NHAÄT DANH MUÏC HAØNG
THANH TOAÙN
GIAÛI QUYEÁT XUAÁT HAØNG
Giaûi thích caùc chöùc naêng:
Ghi nhaän khaùch haøng môùi: Khi coù khaùch haøng môùi ñaët mua haøng thì seõ löu laïi moät soá thoâng tin veà khaùch haøng môùi ñoù (nhö laø Hoï teân khaùch haøng, ñòa chæ, ñieän thoaïi, …).
Giaûi quyeát ñôn ñaët haøng: Sau khi nhaän ñôn ñaët haøng cuûa khaùch haøng thì boä phaän kinh doanh seõ tieán haønh giaûi quyeát ñôn ñaët haøng, neáu ñuû ñieàu kieän thì chaáp nhaän baùn haøng, ngöôïc laïi thì heïn laïi vôùi khaùch haøng haëc töø choái baùn haøng.
Laäp phieáu xuaát haøng: Döïa vaøo caùc ñôn ñaët haøng ñaõ ñöôïc giaûi quyeát, boä phaän kinh doanh seõ tieán haønh laäp phieáu xuaát haøng.
Giaûi quyeát xuaát haøng: Laäp caùc hoaù ñôn chöùng töø xuaát haøng, tieán haønh xuaát haøng cho khaùch mua haøng.
Caäp nhaät danh muïc haøng: Moãi laàn xuaát haøng thì phaûi tieán haønh caäp nhaät laïi danh muïc haøng.
Thanh toaùn: Sau khi giaûi quyeát xuaát haøng thì baét ñaàu laäp phieáu thanh toaùn, tieán haønh thu tieàn baùn haøng.
c. Chöùc naêng thoáng keâ vaø baùo caùo.
THOÁNG KEÂ VAØ BAÙO CAÙO
THOÁNG KEÂ HAØNG NHAÄP
THOÁNG KEÂ HAØNG XUAÁT
THOÁNG KEÂ HAØNG TOÀN
THOÁNG KEÂ NHAÄP XUAÁT CHI TIEÁT
Giaûi thích caùc chöùc naêng:
Thoáng keâ haøng nhaäp: Thoáng keâ löôïng haøng hoaù nhaäp veà theo thaùng hoaëc theo yeâu caàu cuûa ban quaûn lyù.
Thoáng keâ haøng xuaát: Thoáng keâ löôïng haøng hoaù xuaát baùn theo thaùng hoaëc theo yeâu caàu cuûa ban quaûn lyù.
Thoáng keâ haøng toàn: Thoáng keâ löôïng haøng hoaù coøn toàn trong kho theo thaùng hoaëc theo yeâu caàu cuûa ban quaûn lyù.
d. Chöùc naêng tìm kieám.
TÌM KIEÁM
TÌM KIEÁM PHIEÁU NHAÄP HAØNG
TÌM KIEÁM PHIEÁU THU
TÌM KIEÁM PHIEÁU CHI
TÌM KIEÁM PHIEÁU XUAÁT HAØNG
Giaûi thích caùc cöùc naêng:
Tìm kieám phieáu nhaäp haøng: Tieán haønh tìm kieám phieáu nhaäp haøng khi nhaø cung caáp yeâu caàu.
Tìm kieám phieáu xuaát haøng: Tieán haønh tìm kieám phieáu xuaát haøng khi khaùch haøng yeâu caàu.
Tìm kieám phieáu chi: Tieán haønh tìm kieám phieáu chi tieàn khi nhaø cung caáp yeâu caàu.
Tìm kieám phieáu thu: Tieán haønh tìm kieám phieáu thu tieàn khi khaùch haøng yeâu caàu.
IV. BIEÅU ÑOÀ LUOÀNG DÖÕ LIEÄU
Muïc ñích:
Söï dieãn taû laø ôû möùc logic, nghóa laø nhaèm traû lôøi caâu hoûi “Laøm gì?”, maø boû qua caâu hoûi “Laøm nhö theá naøo?”.
Chæ roû caùc chöùc naêng (con) phaûi thöïc hieän ñeå hoaøn taát quaù trình xöû lyù caàn moâ taû.
Chæ roõ caùc thoâng tin ñöôïc chuyeån giao giöõa caùc chöùc naêng ñoù, vaø qua ñoù phaàn naøo thaáy ñöôïc trình töï thöïc hieän cuûa chuùng.
Phaân möùc:
Duøng bieåu ñoà phaân caáp chöùc naêng ta coù caùc möùc nhö sau:
Möùc khung caûnh: coù moät chöùc naêng vôùi caùc luoàng vaøo ra.
Möùc ñænh: chöùc naêng cuûa heä thoáng ñöôïc phaân ra thaønh nhieàu chöùc naêng con.
Möùc döôùi ñænh: giaûi thích moãi chöùc naêng töông töùng cuûa möùc ñænh.
1. Bieåu ñoà luoàng döõ lieäu möùc khung caûnh
NHAØ CUNG CAÁP
KHAÙCH HAØNG
Hoaït ñoäng giao dòch xuaát nhaäp haøng
Thoâng tin veà haøng
Ñôn ñaët haøng
Hoaù ñôn
Töø choái
Phieáu traû tieàn
Haøng hoaù
Thoâng boaù hoaù ñôn sai
Y/C tìm kieám ÑÑH/ PTT
Thoáng keâ
Baùo caùo
Thoâng tin veà haøng
Ñôn ñaët haøng
Töø choái
Hoaù ñôn
Phieáu traû tieàn
Y/C tìm kieám ÑÑH/ PTT
Haøng hoaù
Yeâu caàu thoáng keâ
BAN QUAÛN LYÙ
2. Beåu ñoà luoàng döõ lieäu möùc ñænh
NHAØ CUNG CAÁP
KHAÙCH HAØNG
Quaûn lyù xuaát haøng
Thoâng tin veà haøng
Ñôn ñaët haøng
Hoaù ñôn
Töø choái
Phieáu traû tieàn
Thoâng baùo HÑ sai
Thoâng boaù HÑ sai
Y/C tìm kieám
Thoâng tin veà haøng
Ñôn ñaët haøng
Töø choái
Hoaù ñôn
Phieáu traû tieàn
Y/C tìm kieám
Y/C thoáng keâ
Quaûn lyù nhaäp haøng
BAN QUAÛN LYÙ
Thoáng keâ
Tìm kieám
Danh muïc haøng
Phieáu N/X
Phieáu TT
Y/C tìm kieám
3. Bieåu ñoà luoàng döõ lieäu möùc döôùi ñænh
a. Chöùc naêng quaûn lyù nhaäp haøng
Laäp phieáu thanh toaùn
Khôùp ñôn vôùi haøng veà
Thanh toaùn
Ghi nhaän NCC môùi
Choïn NCC
Laäp ñôn ñaët haøng
Nhaø cung caáp
Ñôn ñaët haøng
Nhaø cung caáp
Phieáu nhaäp haøng
Danh muïc haøng
Ban quaûn lyù
Thoâng tin veà haøng hoaù, nhaø CC
Töø choái
Thoâng tin veà NCC môùi
T/t veà NCC ñöôïc choïn
Ñôn ñaët haøng
Thoâng baùo hoaù ñôn sai
Caäp nhaät DM haøng
Laäp phieáu nhaäp haøng
Hoaù ñôn
Phieáu traû tieàn
Laäp baùo caùo
Phieáu thanh toaùn
b. Chöùc naêng quaûn lyù xuaát haøng
Thanh toaùn
Laäp phieáu thanh toaùn
Ghi nhaän KH môùi
Giaûi quyeát ñôn ñaët haøng
Khaùch haøng
Khaùch haøng
Phieáu xuaát haøng
Danh muïc haøng
Thoâng tin veà haøng hoaù
Töø choái
Thoâng tin veà KH môùi
Ñôn ñaët haøng
Hoaù ñôn
Laäp phieáu xuaát haøng
Hoaù ñôn
Phieáu traû tieàn
Ñôn ñaët haøng
Phieáu thanh toaùn
Thoâng baùo veà hoaù ñôn sai
Giaûi quyeát xuaát haøng
Ñôn ÑH ñöôïc giaûi quyeát
Phieáu xuaát haøng
Phieáu phaùt haøng
Laäp baùo caùo
Ban quaûn lyù
c. Chöùc naêng thoáng keâ
Ban quaûn lyù
Thoáng keâ haøng nhaäp
Laäp nhaät kyù nhaäp xuaát chi tieát
Thoáng keâ haøng toàn
Thoáng keâ haøng xuaát
Phieáu N/X
Yeâu caàu thoáng keâ
Yeâu caàu
Yeâu caàu
Yeâu caàu thoáng keâ
d. Chöùc naêng tìm kieám
Nhaø CC
Tìm kieám phieáu nhaäp haøng
Tìm kieám phieáu xuaát haøng
Tìm kieám phieáu TT
Tìm kieám phieáu TT
Phieáu nhaäp xuaát
Phieáu thanh toaùn
Y/ c tìm kieám PN
Y/C tìm kieám PX
Y/c tìm kieámPTT
Khaùch haøng
Y/C tìm kieám PTT
V. MOÂ HÌNH THÖÏC THEÅ
1. Moät soá khai nieäm veà moâ hình thöïc theå
Khaùi nieäm: Laø moâ hình döõ lieäu logic ñöôïc xaây döïng treân caùc khaùi nieäm logic nhö: Thöïc theå, kieåu thöïc theå, thuoäc tính vaø quan heä.
Thöïc theå: Thöïc theå laø moät chuû ñieåm, moät nhieäm vuï, moät ñoái töôïng hay moät söï kieän ñaùng quan taâm trong thöïc teá, keå caû thoâng tin maø noù löu giöõ laø coù ích cho heä thoáng.
Kieåu thöïc theå: Laø taäp hôïp caùc thöïc theå coù cuøng baûn chaát ñöôïc bieåu dieãn.
Thuoäc tính: Sau khi xaùc ñònh ñöôïc kieåu thöïc theå vaø thöïc theå thì ta xeùt ñeán nhöõng thoâng tin naøo caàn thieát phaûi ñöôïc löu giöõ cho moãi thöïc theå, ñoù chính laø caùc thuoäc tính. Caùc thuoäc tính ñaëc tröng cuûa thöïc theå thöôøng ñöôïc bieåu dieãn baèng caùc tröôøng hoaëc coät trong baûng.
Quy taéc xaùc ñònh caùc thuoäc tính cuûa thöïc theå:
Töø tri thöùc cuûa chính baûn thaân veà thöïc theå coâng vieäc chung trong lónh vöïc mình ñang nghieân cöùu maø ñöa ra caùc thuoäc tính trong moãi thuïc theå.
Töø ngöôøi tieáp xuùc phoûng vaán.
Töø vieäc xem xeùt caùc baûng bieåu, taøi lieäu lieân quan ñeán lónh vöïc ñang nghieân cöùu.
Lieân keát: Laø söï keát noái hay lieân quan giöõa hai hay nhieàu thöïc theå phaûn aùnh söï raøng buoäc veà quaûn lyù.
Kieåu lieân keát: Laø taäp hôïp nhieàu lieân keát coù daïng gioáng nhau giöõa caùc caëp thöïc theå.
Coù 3 kieåu lieân keát nhö sau:
Lieân keát Moät – Moät:
Moät thöïc theå thuoäc kieåu thöïc theå A lieân keát vôùi moät thöïc theå thuoäc kieåu thöïc theå B vaø ngöôïc laïi.
A
B
Lieân keát Moät – Nhieàu:
Moät thöïc theå thuoäc kieåu thöïc theå A lieân keát vôùi nhieàu thöïc theå thuoäc kieåu thöïc theå B.
Moät thöïc theå thuoäc kieåu thöïc theå B lieân keát vôùi moät thöïc theå thuoäc kieåu thöïc theå A.
A
B
Lieân keát Nhieàu – Nhieàu:
Moät thöïc theå thuoäc kieåu thöïc theå A lieân keát vôùi nhieàu thöïc theå thuoäc kieåu thöïc theå B.
Moät thöïc theå thuoäc kieåu thöïc theå B lieân keát vôùi nhieàu thöïc theå thuoäc kieåu thöïc theå A.
A
B
Quy taéc xaùc ñònh lieân keát:
Moät lieân keát toàn taïi giöõa hai thöïc theå khaùc nhau thuoäc hai baûng khaùc nhau neáu caàn phaûi giöõ thoâng tin trong thöïc theå naøy veà thöïc theå kia.
Trong lieân keát Moät – Nhieàu, thöïc theå giöõ thoâng tin keát noái theo ñònh nghóa laø ôû ñaàu nhieàu.
Caùc lieân keát giaùn tieáp (Nhieàu – Nhieàu) ñöôïc bieán ñoåi thaønh caùc lieân keát Moät - Nhieàu.
Chuaån hoaù döõ lieäu: Chuaån hoaù laø quaù trình phaân tích chuyeån hoùa caùc thöïc theå thaønh moät daïng maø toái thieåu vieäc laëp laïi, khoâng dö thöøa nhöng döõ lieäu vaãn ñaày ñuû.
Caùc quy taéc chuaån hoaù:
Quy taéc chuaån hoaù 1: Baûng khoâng ñöôïc chöùa nhöõng thuoäc tính xuaát hieän nhieàu laàn.
Quy taéc chuaån hoaù 2: Moïi thuoäc tính phaûi phuï thuoäc haøm vaøo toaøn boä khoaù.
Quy taéc chuaån hoaù thöù 3: Moãi thuoäc tính chæ phuï thuoäc haøm vaøo toaøn boä khoaù maø khoâng phuï thuoäc haøm vaøo baát cöù thuoäc tính naøo khaùc trong baûng.
Treân ñaây laø sô löôïc lyù thuyeát veà vieäc xaây döïng cô sôû döõ lieäu cho heä thoáng thoâng tin. Töø söï phaân tích ñaàu vaøo vaø ñaàu ra cuûa heä thoáng, töø caùc bieåu ñoà luoàng döõ lieäu, ta seõ thaáy roõ veà cô sôû döõ lieäu cuûa heä thoáng.
2. Xaùc ñònh caùc thöïc theå cuûa heä thoáng vaø caùc thuoäc tính cuûa chuùng
Vôùi baøi toaùn quaûn lyù giao dòch xuaát nhaäp haøng, heä thoáng goàm coù caùc thöïc theå vaø thuoäc tính nhö sau (sau khi ñaõ chuaån hoaù):
Khaùch haøng (Duøng cho caû nhaø cung caáp vaø khaùch mua haøng):
Maõ KH
Hoï KH
Teân KH
Teân giao dòch
Soá nhaø KH
DT khaùch haøng
Fax KH
Taøi khoaûn
ST nôï coù theå
Maõ huyeän
Maõ ñöôøng
Maõ NH
Maët haøng :
Maõ haøng
Teân haøng
SL toàn TT
SL toàn TD
Maõ HSX
Maõ DVT
Maõ nhoùm
Quaûn lyù kho :
Maõ kho
Teân kho
DT kho
Fax kho
Soá nhaø kho
Thuû kho
Maõ ñöôøng
Quaûn lyù ñôn ñaët haøng :
Maõ DDH
Maõ KH
Ngaøy DH
Haïn ngaøy giao
Doøng ñôn ñaët haøng
Maõ DDH
Maõ haøng
Soá löôïng DH
Ñôn giaù DH
Quaûn lyù phieáu nhaäp xuaát haøng :
Maø PNXH
Maõ DDH
Maõ kho
Ngaøy NXH
Ngaøy HTT
Ngaøy laäp PNX
Quaûn lyù doøng phieáu nhaäp xuaát haøng :
Maø PNXH
Maõ haøng
Soá löôïng NXH
Ñôn giaù NXH
Quaûn lyù phieáu thanh toaùn :
Maõ PTT
Maõ PNXH
Ngaøy TT
Soá tieàn
Quaûn lyù ñöôøng :
Maõ ñöôøng
Teân ñöôøng
Quaûn lyù ngaân haøng :
Maõ NH
Teân NH
Quaûn lyù huyeän :
Maõ huyeän
Teân huyeän
Maõ tænh
Quaûn lyù tænh :
Maõ tænh
Teân tænh
Maõ nöôùc
Quaûn lyù nöôùc :
Maõ nöôùc
Teân nöôùc
Quaûn lyù haõng saûn xuaát :
Maõ HSX
Teân HSX
Maõ nöôùc
Quaûn lyù ñôn vò tính :
Maõ DVT
Teân DVT
Quaûn lyù nhoùm haøng :
Maõ nhoùm
Teân nhoùm
Xaây döïng moâ hình thöïc theå lieân keát
KHAÙCH HAØNG
Maõ KH
Hoï KH
Teân KH
Teân giao dòch
Soá nhaø KH
DT khaùch haøng
Fax KH
Taøi khoaûn
ST nôï coù theå
Maõ huyeän
Maõ ñöôøng
Maõ NH
HUYEÄN
Maõ huyeän
Teân huyeän
Maõ tænh
ÑÖÔØNG
Maõ ñöôøng
Teân ñöôøng
KHO
Maõ kho
Teân kho
DT kho
Fax kho
Soá nhaø kho
Thuû kho
Maõ ñöôøng
TÆNH
Maõ tænh
Teân tænh
Maõ nöôùc
NÖÔÙC
Maõ nöôùc
Teân nöôùc
HAÕNG SX
Maõ HSX
Teân HSX
Maõ nöôùc
DV TÍNH
Maõ DVT
Teân DVT
MAËT HAØNG
Maõ haøng
Teân haøng
SL toàn TT
SL toàn TD
Maõ HSX
Maõ DVT
Maõ nhoùm
NHOÙM
Maõ nhoùm
Teân nhoùm
NGAÂN HAØNG
Maõ NH
Teân NH
ÑÔNDHAØNG
Maõ DDH
Maõ KH
Ngaøy DH
Haïn ngaøy giao
DOØNGÑÔNDH
Maõ DDH
Maõ haøng
Soá löôïng DH
Ñôn giaù DH
NX HAØNG
Maõ PNXH
Maõ DDH
Maõ kho
Ngaøy NXH
Ngaøy HTT
Ngaøy laäp PNX
THANH TOAN
Maõ PTT
Maõ PNXH
Ngaøy TT
Soá tieàn
DOØNGNX HAØNG
Maõ PNXH
Maõ haøng
Soá löôïng NXH
Ñôn giaù NXH
VI. MOÂ HÌNH TOÅ CHÖÙC DÖÕ LIEÄU
Moâ hình naøy chính laø löôïc ñoà cô sôû döõ lieäu cuûa heä thoáng. Ñaây laø böôùc trung gian chuyeån ñoåi giöõa moâ hình thöïc theå (gaàn vôùi ngöôøi söû duïng) vaø moâ hình vaät lyù döõ lieäu (moâ hình trong maùy tính), chuaån bò cho vieäc caøi ñaët heä thoáng.
Töø moâ hình thöïc theå ôû treân ta chuyeån thaønh moâ hình toå chöùc döõ lieäu cuûa baøi toaùn nhö sau :
NUOC(MaNuoc, TenNuoc)
TINH(MaTinh, TenTinh, MaNuoc)
HUYEN(MaHuyen, TenHuyen, MaTinh)
DUONG(MaDuong, TenDuong)
HANG SX(MaHSX, TenHSX, MaNuoc)
DVTINH(MaDVT, TenDVT)
NHOM(MaNhom, TenNhom)
MATHANG(MaHang, TenHang, SLTonTT, SLTonTD, MaDVT, MaHSX, MaNhom)
KHO(MaKho, TenKho, DTKho, FaxKho, SoNhaKho, ThuKho, MaDuong)
NGANHANG(MaNH, TenNH)
KHACHHANG(MaKH, HoKH, TenKH, TenGiaoDich, SoNhaKH, DTKhachHang, FaxKH, TaiKhoan, STNoCoThe, MaDuong, MaHuyen, MaNH)
DONDHANG(MaDDH, NgayDH, HanNgaygiao MaKH)
DONGDONDH(MaDDH, MaHang, SoLuongDH, DonGiaDH)
NXHANG(MaPNXH, NgayNXH, NgayHTT, Ngaøy laäp PNX, MaDDH, MaKho)
DONGNXHANG(MaPNXH, MaHang, SoLuongNXH, DonGiaNXH)
THANHTOAN(MaPTT, MaPNXH, NgayTT, SoTien)
VII. MOÂ HÌNH VAÄT LYÙ DÖÕ LIEÄU
Caùc baûng ñöôïc thieát keá trong heä thoáng:
NUOC(MaNuoc, TenNuoc)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaNuoc (K)
Char
2
Len() =2
TenNuoc
Varchar
30
MaNuoc : Chöõ vieát taét cuûa moät teân nöôùc treân theá giôùi.
TenNuoc : Teân cuûa moät nöôùc.
Ví duï:
MaNuoc = VN coù TenNuoc = Vieät Nam
MaNuoc = TQ coù TenNuoc = Trung Quoác
MaNuoc = ML coù TenNuoc = Malaysia
YÙ nghóa: Moãi nöôùc coù moät maõ soá rieâng ñeå phaân bieät caùc nöôùc vôùi nhau.
TINH(MaTinh, TenTinh, MaNuoc)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaTinh (K)
Char
4
Len() = 4
TenTinh
Varchar
20
MaNuoc
Char
2
Lookup(NUOC)
MaTinh : Soá thöù töï cuûa tænh trong nöôùc. Vieät Nam coù döôùi 100 tænh, neân ta choïn 2 kyù töï ñeå ñaùnh soá thöù töï cuûa tænh.
2 Kyù töï ñaàu laø maõ nöôùc.
2 Kyù töï tieáp theo laø soá thöù töï tænh trong nöôùc.
TeânTinh: Baét ñaàu laø Tp cho thaønh phoá tröïc thuoäc trung öông, T cho tænh vaø tieáp theo laø teân tænh hay thaønh phoá.
Ví duï:
MaTinh = VN01 coù TenTinh = Tp.Haø Noäi.
MaTinh = VN02 coù TenTinh =T.Quaûng Ninh.
YÙ nghóa: Moãi moät tænh coù moät maõ soá rieâng ñeå phaân bieät caùc tænh vôùi nhau.
HUYEN(MaHuyen, TenHuyen, MaTinh)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaHuyen (K)
Char
6
Len()=6
TenHuyen
Varchar
25
MaTinh
Char
4
Lookup(TINH)
MaHuyen : 4 kyù töï ñaàu laø maõ nöôùc vaø maõ tænh, hai kyù töï sau laø soá thöù töï cuûa huyeän trong tænh. Moãi tænh khoâng quaù 100 huyeän neân duøng 2 kyù töï.
TenHuyen : Baét ñaàu laø Tp cho thaønh phoá tröïc thuoäc Tænh, Q : cho quaän, H cho huyeän, TX cho thò xaõ vaø tieáp theo laø teân thaønh phoá, quaän, huyeän, thò xaõ.
Ví duï:
MaHuyen = VN0101 coù TenHuyen = Q. Ba Ñình.
MaHuyen = VN0201 coù TenHuyen =Tp. Haï Long.
YÙ nghóa: Moãi huyeän ñöôïc phaân bieät bôûi moät maõ huyeän khaùc nhau ôû trong moät Tænh cuõng nhö phaân bieät vôùi caùc huyeän khaùc ôû caùc tænh khaùc, vì trong maõ huyeän ta coù keøm theo 2 kí töï cuûa maõ tænh neân coù theå phaân bieät ñöôïc raèng ta ñang bieãu dieãn maõ cuûa caùc huyeän ôû trong tænh naøo.
DUONG(MaDuong, TenDuong)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaDuong (K)
Char
4
TenDuong
Varchar
30
MaDuong : Vieát taét caùc kyù töï ñaàu cuûa teân ñöôøng.
TenDuong : Teân ñöôøng.
Ví duï:
MaDuong = PCT coù TenDuong = Phan Chu Trinh.
MaDuong = NTMK coù TenTinh = Nguyeãn Thò Minh Khai.
YÙ nghóa: Moãi teân ñöôøng coù moät maõ rieâng ñeå phaân bieät giöõa caùc ñöôøng vôùi nhau.
HANG SX(MaHSX, TenHSX, MaNuoc)
Teân thuoäc tính
Lieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaHSX (K)
Char
4
Len()=4
Ten HSX
Varchar
50
MaNuoc
Char
2
Lookup(NUOC)
MaHSX : Hai kyù töï ñaàu laø maõ nöôùc, hai kyù töï sau laø soá thöù töï haõng saûn xuaát trong nöôùc.
TenHSX : Teân cuûa haõng saûn xuaát.
MaNuoc : Maõ nöôùc cuûa nöôùc coù haõng saûn xuaát ñoù.
Ví duï:
MaHSX = ML01 coù TenHSX = INTERFOODS PROCESSING ….
MaHSX = JP01 coù TenHSX = HITACHI.
YÙ nghóa: Moãi haõng saûn xuaát coù moät maõ rieâng ñeå phaân bieät giöõa caùc haõng saûn xuaát vôùi nhau.
DONVITINH(MaDVT, TenDVT)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaÑVT (K)
Char
1
Len()=1
TenÑVT
Varchar
7
MaDVT: Vieát taét kyù töï ñaàu cuûa teân ñôn vò tính.
TenDVT : Teân ñôn vò tính.
Ví duï :
MaDVT = T coù TenDVT = Thuøng.
MaDVT = H coù TenDVT = Hoäp.
YÙ nghóa: Moãi ñôn vò tính coù moät maõ rieâng ñeå phaân bieät giöõa caùc ñôn vò tính vôùi nhau.
NHOM(MaNhom, TenNhom)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaNhom (K)
Char
1
Len()=1
TenNhom
Varchar
50
MaNhom : Duøng moät chöõ caùi ñeå kyù hieäu nhoùm.
TenNhom : Teân nhoùm haøng.
Ví duï:
MaNhom = A coù TenNhom = Nhoùm haøng duøng ngay.
MaNhom = B coù TenNhom = Nhoùm haøng phaûi qua cheá bieán môùi duøng ñöôïc.
MaNhom = C coù TenNhom = Nhoùm haøng baùnh keïo.
YÙ nghóa: Moãi nhoùm haøng coù moät maõ rieâng ñeå phaân bieät giöõa caùc nhoùm vôùi nhau.
MATHANG(MaHang, TenHang, SLTonTT, SLTonTD, MaDVT, MaHSX, MaNhom)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaHang (K)
Char
4
Len()=4
TenHang
Varchar
50
SLTonTT
Integer
8
SLTonTD
Integer
8
MaDVT
Char
1
Lookup(DONVITINH)
MaH SX
Char
4
Lookup(HANGSX)
MaNhom
Char
1
Lookup(NHOM)
MaHang : 1 kyù töï ñaàu tieân laø maõ nhoùm, 3 kyù töï tieáp theo laø soá thöù töï maët haøng trong nhoùm.
TenHang : Teân maët haøng.
SLTonTT : Soá löôïng toàn toái thieåu öùng vôùi moät maët haøng trong kho. Neáu soá löôïng maët haøng ñoù toàn trong kho döôùi möùc toái thieåu thì phaûi nhaäp theâm vaøo.
SLTonTD : Soá löôïng toàn toái ña öùng vôùi moät maët haøng ôû trong kho. Neáu nhaäp theâm soá löôïng maët haøng naøo ñoù thì toång soá löôïng trong kho khoâng ñöôïc vöôït quaù soá löôïng toàn toái ña cuûa maët haøng ñoù.
MaDVT : Maõ ñôn vò tính cuûa ñôn vò tính.
MaHSX : Maõ haõng saûn xuaát cuûa haõng saûn xuaát.
MaNhom : Maõ nhoùm cuûa nhoùm haøng.
Ví duï:
MaHang = A001 coù TenHang = Bird’s Nest.
MaHang = B001 coù TenHang = Coconut Milk.
MaHang = C001 coù TenHang = Chocolate.
YÙ nghóa: Moãi maët haøng coù moät maõ rieâng ñeå phaân bieät giöõa caùc maët haøng vôùi nhau.
KHO(MaKho, TenKho, DTKho, FaxKho, SoNhaKho, ThuKho, MaDuong)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaKho (K)
Char
5
TenKho
Varchar
50
DTKho
Varchar
10
FaxKho
Varchar
10
SoNhaKho
Varchar
20
ThuKho
Varchar
30
MaDuong
Char
4
Lookup(DUONG)
MaKho : 4 kyù töï ñaàu laø caùc kyù töï vieát taét teân ñöôøng, 1 kyù töï sau laø soá thöù töï kho treân ñöôøng ñoù.
TenKho : Teân kho haøng.
Ví duï:
MaKho = NTMK1 coù TenKho = Kho nöôùc.
MaKho = NTMK2 coù TenKho = Kho baùnh keïo.
YÙ nghóa: Moãi kho coù moät maõ rieâng ñeå phaân bieät giöõa caùc kho vôùi nhau.
NGANHANG(MaNH, TenNH)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaNH (K)
Char
4
TenNH
Varchar
30
MaNH : Vieát taét caùc kyù töï ñaàu cuûa teân ngaân haøng.
TenNH : Teân ngaân haøng.
Ví duï:
MaNH = NHNH coù TenNH = Ngaân haøng noâng nghieäp.
MaNH = NHNT coù TenNH = Ngaân haøng ngoaïi thöông.
YÙ nghóa: Moãi ngaân haøng coù moät maõ rieâng ñeå phaân bieät giöõa caùc ngaân haøng vôùi nhau.
KHACHHANG(MaKH, HoKH, TenKH, TenGiaoDich, SoNhaKH, DTKhachHang, FaxKH, TaiKhoan, STNoCoThe, MaDuong, MaHuyen, MaNH)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaKH (K)
Char
5
Len()=5
HoKH
Varchar
23
TenKH
Varchar
7
TenGiaoDich
Varchar
30
SoNhaKH
Varchar
20
DTKhachHang
Varchar
10
FaxKH
Varchar
10
TaiKhoan
Varchar
16
STNoCoThe
Money
8
MaDuong
Char
4
Lookup(DUONG)
MaHuyen
Char
6
Lookup(HUYEN)
MaNH
Char
4
Lookup(NGANHANG)
MaKH : 1 kyù töï ñaàu duøng ñeå phaân bieät nhaø cung caáp vaø khaùch mua haøng (C hay K), 4 kyù töï sau laø soá thöù töï khaùch haøng.
HoKH : Hoï khaùch haøng, ñoä daøi 23 kyù töï.
TenKH : Teân khaùch haøng, ñoä daøi 7 kyù töï.
Ví duï:
MaKH = K0001 coù HoKH & TenKH = Leâ Vaên Nam.
MaKH = K0002 coù HoKH & TenKH = Hoà Thò Phöôïng.
MaKH = C0001 coù HoKH & TenKH = Traàn Thò Myõ Hoa.
YÙ nghóa: Moãi khaùch haøng coù moät maõ rieâng ñeå phaân bieät giöõa caùc khaùch haøng vôùi nhau.
DONDHANG(MaDDH, NgayDH, MaKH)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöùc
Raøng buoäc toaøn veïn
MaDDH(K)
Char
5
Len() = 5
NgayDH
DateTime
Shortdste
HanNgayGiao
Datetime
Shortdate
MaKH
Char
5
Lookup(KHACHHANG)
MaDDH : 1 kyù töï ñaàu duøng ñeå phaân bieät ñôn ñaët mua haøng cuûa khaùch haøng hay ñôn coâng ty göûi nhaø cung caáp (M hay B), 4 kyù töï sau laø soá thöù töï ñôn ñaët haøng.
YÙ nghóa: Moãi ñôn ñaët haøng coù moät taäp hôïp maõ rieâng ñeå phaân bieät giöõa caùc ñôn ñaët haøng vôùi nhau.
DONGDONDH(MaDDH, MaHang, SoLuongDH, DonGiaDH, NgayGiao)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaDDH (K)
Char
5
Len()=5
MaHang (K)
Char
4
Lookup(MATHANG)
SoLuongDH
Integer
8
DonGiaDH
Money
8
NXHANG(MaPNXH, NgayNXH, NgayHTT, Ngaøy laäp PNX, MaDDH, MaKho)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaPNXH (K)
Char
5
Len()=5
NgayNXH
Datetime
Shortdate
NgayHTT
Datetime
Shortdate
NgaylapPNX
Datetime
Shortdate
MaDDH
Char
5
Lookup(DONGDONDH)
MaKho
Char
5
Lookup(KHO)
MaPXH : 1 kyù töï ñaàu duøng ñeå phaân bieät phieáu nhaäp hay phieáu xuaát haøng (N hay X), 4 kyù töï sau laø thöù töï phieáu xuaát hay nhaäp haøng.
YÙ nghóa: Moãi ñôn ñaët haøng coù moät taäp hôïp maõ rieâng ñeå phaân bieät giöõa caùc ñôn ñaët haøng vôùi nhau.
DONGNXHANG(MaPNXH, MaHang, SoLuongNXH, DonGiaNXH)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaPNXH (K)
Char
5
Len()=5
MaHang (K)
Char
4
Len()=4
SoLuongNXH
Integer
8
DonGiaNXH
Money
8
THANHTOAN(MaPTT, MaPNXH, NgayTT, SoTien)
Teân thuoäc tính
Kieåu döõ lieäu
Kích thöôùc
Raøng buoäc toaøn veïn
MaPTT (K)
Char
5
Len()=5
NgayTT
Datetime
Shortdate
SoTien
Money
8
MaPNXH
Char
5
Lookup(NXHANG)
MaPTT : 1 kyù töï ñaàu duøng ñeå phaân bieät phieáu thu hay phieáu chi (T hay C), 4 kyù töï sau laø soá thöù töï phieáu thanh toaùn.
YÙ nghóa : Moãi phieáu thanh toaùn coù moät taäp hôïp maõ rieâng ñeå phaân bieät giöõa caùc phieáu thanh toaùn vôùi nhau.
VIII. MOÂ HÌNH TÖØ ÑIEÅN DÖÕ LIEÄU
STT
TEÂN THUOÄC TÍNH
KIEÅU DÖÕ LIEÄU
ÑOÄ DAØI
VÍ DUÏ
1
MaNuoc
Char
2
VN
2
TenNuoc
Varchar
30
Vieät Nam
3
MaTinh
Char
4
VN01
4
TenTinh
Varchar
20
Tp. Haø Noäi
5
MaHuyen
Char
6
VN0101
6
TenHuyen
Varchar
25
Q. Ba Ñình
7
MaDuong
Char
NTMK
8
TenDuong
Varchar
30
Nguyeãn Thò Minh Khai
9
MaHSX
Char
4
JP01
10
TenHSX
Varchar
50
HITACHI
11
MaDVT
Char
1
T
12
TenDVT
Varchar
7
Thuøng
13
MaNhom
Char
1
A
14
TenNhom
Varchar
50
Nhoùm haøng duøng ngay
15
MaHang
Char
4
A001
16
TenHang
Varchar
50
Bird’s nest
17
SLTonTT
Integer
8
50
18
SLTonTD
Integer
8
250
19
MaKho
Char
5
NTMK1
20
TenKho
Varchar
50
Kho nöôùc
21
DTKho
Varchar
10
058.834223
22
FaxKho
Varchar
10
058.834644
23
SoNhaKho
Varchar
20
58
24
ThuKho
Varchar
30
Leâ Vaên Taøi
25
MaNH
Char
NHNN
27
TenNH
Varchar
30
Ngaân haøng noâng nghieäp
28
MaKH
Char
5
K0001
29
HoKH
Varchar
23
Hoà Thò
30
TenKH
Varchar
7
Phöôïng
31
TenGiaoDich
Varchar
30
SAO MAI
33
SoNhaKH
Varchar
20
35/11
34
DTKhachHang
Varchar
10
058.832653
35
FaxKH
Varchar
10
058.832253
36
TaiKhoan
Varchar
0061.000031.8.1
37
STNoCoThe
Money
8
1.500.000
38
MaDDH
Char
5
B0001
39
NgayDH
DateTime
Shortdate
10/07/2003
40
SoLuongDH
Integer
8
40
41
DonGiaDH
Money
8
90.000
42
HanNgayGiao
Datetime
Shortdate
29/07/2003
43
MaPNXH
Char
5
X0001
44
SoLuongNXH
Integer
8
40
45
DonGiaNXH
Money
8
90.000
46
NgayNXH
Datetime
Shortdate
30/07/2003
47
NgayHTT
Datetime
Shortdate
01/08/2003
48
MaPTT
Char
5
T0001
49
NgayTT
Datetime
Shortdate
01/08/2003
50
SoTien
Money
8
3.600.000
CHÖÔNG III
LÖÏA CHOÏN MOÂI TRÖÔØNG CAØI ÑAËT VAØ
GIÔÙI THIEÄU CAÙC COÂNG NGHEÄ LIEÂN QUAN
Vôùi muïc tieâu xaây döïng moät phaàn meàm ñaùp öùng ñöôïc caùc chöùc naêng trong vieäc quaûn lyù giao dòch xuaát nhaäp, ñoàng thôøi deã söû duïng vaø thaân thuoäc vôùi ngöôøi söû duïng, em löïa choïn giaûi phaùp laäp trình öùng duïng treân neàn Windows ñöôïc caøi ñaët baèng ngoâ ngöõ laäp trình Microsoft VisualBasic 6.0 vôùi heä quaûn trò cô sôû döõ lieäu Microsoft SQL Server.
I. Giôùi thieäu veà Visual Basic 6.0.
Microsoft Visual Basic 6.0 tuy khoâng coøn laø hieän thaân môùi nhaát vaø ñoäc ñaùo cuûa ngoân ngöõ BAISIC nhö caùch ñaây vaøi naêm nhöng noù vaãn coøn tính naêng öu vieät cho baïn heä thoáng phaùt trieån öùng duïng cuûa Windows toaøn dieän vaø troïn goùi. Microsoft Visual Basic 6.0 coù nhieàu coâng cuï hoå trôï maø baïn coù theå vieát theâm vaø bieân dòch caùc file trôï giuùp. Noù bao goàm:
1. Caùc coâng cuï ñieàu khieån ( controls).
Bao goàm caùc coâng cuï treân cöûa soå toolbox , nhöõng caùi maø baïn coù theå ñaët vaøo bieåu maãu ñeå töông taùc vôùi ngöôøi duøng vaø ñieàu khieån luoàng chöông trình.
2. Chöông trình ( Program).
Laø taäp hôïp caùc caâu leänh ñeå cho maùy tính thöïc hieän caùc coâng vieäc naøo ñoù theo yù muoán ngöôøi laäp trình. Baûn thaân Microsoft Visual Basic laø trình öùng duïng. Baïn taûi vaø thöïc hieän heä thoáng gioáng nhö thöïc hieän caùc chöông trình öùng duïng khaùc. Noù coøn laø coâng cuï raát tuyeät vôøi, caùc laäp trình vieân vieát, kieåm tra vaø chaïy caùc trình öùng duïng cuûa Windows. Noù cung caáp caùc Form windows laø vuøng laøm vieäc, noù duy trì caùc ñoái töôïng töông taùc cuûa chöông trình nhö caùc nuùt leänh, caùc nhaõn, caùc hôïp thoaïi vaên baûn, caùc thanh cuoän vaø caùc coâng cuï ñieàu khieån khaùc.
Ñeà aùn (Project): laø taäp hôïp caùc file baïn taïo cho chöông trình öùng duïng Windows cuûa mình.
Wizard : Ñaây laø caùc hoäp thoaïi hoûi vaø traû lôøi töï ñoäng laøm vieäc.
Trình bieân dòch (Compiler): laø heä thoáng chuyeån ñoåi chöông trình baïn vieát thaønh trình öùng duïng khaû thi cuûa maùy tính.
Developer Studio: laø moâi tröôøng phaùt trieån cuûa Visual Basic. Maëc duø Microsoft Visual Basic laø ngoân ngöõ laäp trình toaøn dieän, nhöng noù vaãn duy trì ngoân ngöõ BASIC thöøa keá noù. Caùc laäp trình vieân vaøo cuoái thaäp nieân 1950 ñaõ phaùt trieån ngoân ngöõ laäp trình BASIC cho caùc laäp trình vieân sô caáp. BASIC deã söû duïng hôn caùc ngoân ngöõ laäp trình khaùc nhieàu laàn, nhö COBOL vaø FORTRAN. Microsoft khoâng bao giôø queân neàn taûng cuûa VB khi phaùt trieån noù. Noù giuùp cho ngöôøi laäp trình coù ñöôïc nhieàu chöông trình Windows chæ trong thôøi gian ngaén.
Microsoft Visual Basic 6.0 coù nhieàu aán baûn khaùc nhau bao goàm : Standard, Profectional vaø Enterprise. Aán baûn Enterprise cung caáp cho caùc laäp trình vieân phaàn meàm client /server vôùi caùc coâng cuï môû roäng cho caùc maùy tính ôû xa vaø phaân phoái caùc trình öùng duïng. Microsoft taêng cöôøng tính naêng laøm vieäc treân maïng, moâi tröôøng phaân phoái cho nhöõng ngöôøi duøng phieân baûn Enterprise.
Moät soá tính naêng môùi trong Visual Basic 6.0 :
Microsoft Visual Basic 6.0 coù nhieàu tính naêng môùi, caùc ñieàu khieån môùi cho pheùp ta vieát chöông trình öùng duïng keát hôïp giao dieän, caùc xöû lyù vaø tính naêng cuûa office 97 vaø trình duyeät WEB Internet Explorer. Microsoft Visual Basic 6.0 cho pheùp ta laäp trình ñeå theâm ñieàu khieån vaøo döï aùn töï ñoäng vaø coù theå taïo ra caùc ActiveX hieäu chænh. Ta cuõng coù theå vieác caùc öùng duïng phía maùy chuû ( server-side) duøng HTML ñoäng nhuùng keát vôùi caùc thö vieän lieân keát ñoäng cuûa Internet Information Server. Moät vaøi öùng duïng vôùi caùc caõi tieán giuùp cho truy caäp döõ lieäu ôû taàm côû vó moâ lieân quan ñeán haøng traêm, haøng nghìn ngöôøi söû duïng qua maïng hay qua Internet.
3. Laøm vieäc vôùi Microsoft Visual Basic 6.0.
3.1. Khaùm phaù döõ lieäu môùi.
Visual Basic cung caáp caùc ñoái töôïng döõ lieäu ActiveX ( ActiveX Data Object – ADO ). Trong caùc phieân baûn tröôùc cuûa VB, truy caäp döõ lieäu ñöôïc thöïc hieän thoâng qua DAO ( Ñoái töôïng truy caäp döõ lieäu- Data Access Object ) vaø RDO ( Ñoái töôïng döõ lieäu töø xa- Remote Data Object). ADO toång hôïp vaø thay theá caùc kyõ thuaät naøy. ADO deã duøng hôn vaø coù taàm hoaït ñoäng roäng hôn. Ta coù theå duøng ADO ñeå keát noái vôùi cô sôû döõ lieäu cuûa moät maùy ñeå baøn hoaëc moät maùy chuû chöùa cô sôû döõ lieäu ôû xa. Hôn theá nöõa ADO coøn cho pheùp truy caäp nhieàu kieåu döõ lieäu, ví duï thö ñieän töû.
Kyõ thuaät ADO hieän nay chöùa trong ñieàu kieån môùi, ñieàu kieån döõ lieäu ADO. Noù troâng gioáng nhö caùc ñieàu khieån döõ lieäu trong caùc phieân baûn tröôùc, nhöng phaàn thuoäc tính cuûa ñieàu khieån, ta seõ thaáy coù nhieàu ñieåm khaùc. Noù cho pheùp keát noái vôùi cô sôû döõ lieäu ñeå baøn hay cô sôû döõ lieäu maùy chuû ODBC treân maïng, hoaëc ta coù theå taïo keát noái ñeán caùc cô sôû döõ lieäu khaùc.
Ngoaøi ADO, Visual Basic 6 coøn coù boä coâng cuï kyõ thuaät môùi giuùp truy caäp döõ lieäu deã daøng hôn. Trình thieát keá moâi truôøng döõ lieäu cho pheùp cho pheùp xem xeùt vaø thao taùc döõ lieäu trong CSDL khaùc nhau, bôûi vì baûn thaân moâi tröôøng döõ lieäu laø caùc ñoái töôïng, ta coù theå söû duïng chuùng nhö moät ñieàu khieån döõ lieäu. Thaäm chí ta coù theå gaén noù vôùi caùc ñieàu khieån khaùc nhö hôïp vaên baûn hay nhaõn.
Moät vaøi ñieàu khieån döõ lieäu khaùc cho pheùp ta taän duïng caùc theá maïnh cuûa ñieàu khieån döõ lieäu ADO. Ñieàu khieån DataGrid cho pheùp xem döõ lieäu döôùi daïng baûng vaø caùc doøng vaø coät. DataList vaø DataCombo töông töï nhö DBList vaø Dbcombo trong caùc phieân baûn tröôùc, ta coù theå duøng chuùng ñeå laáy moät danh saùch döõ lieäu töø ñieàu khieån ADO trong caáu hình hôïp danh saùch ( ListBox ) hoaëc hôïp keát hôïp ( ComboBox) hoaëc chuùng ta coù theå söû duïng FlexGrid ñeå xem nhöõng döõ lieäu phöùc taïp.
Visual Basic 6.0 môû roäng khaû naêng baùo caùo vôùi caùc trình baùo caùo döõ lieäu cho pheùp taïo, xem tröôùc vaø in caùc baùo caùo trong Visual Basic töông töï nhö ACCESS. Ta coù theå laáy caùc ñieàu khieån baùo caùo töø hôïp cong cuï baùo caùo döõ lieäu môùi vaø ñöa vaøo bieåu maåu baùo caùo döõ lieäu. Sau ñoù goïi phöông thöùc PrintReport() cuûa baùo caùo döõ lieäu.
3.2. Boå sung môùi veà laäp trình höôùng ñoái töôïng.
Visual Basic 6.0 giuùp taïo caùc lôùp vaø ñieàu khieån ActiveX phong phuù hôn. Giôø ñaây ta coù theå löu döõ lieäu qua caùc lôùp töï taïo töø session naøy sang session khaùc thoâng qua tuùi thuoäc tính ( Property bag ). Ta cuõng coù theå taïo hai kieåu lôùp hieäu chænh data-aware laø data source vaø Data consumers. Caùc kieåu lôùp döõ lieäu naøy haïot ñoäng töông töï nhö caùc ñoái töôïng döõ lieäu ADO, nhöng chuùng ñaùp öùng ñöôïc yeâu caàu cuûa khaùch haøng nhieàu hôn.
Ñoái vôùi ñieàu khieån ActiveX, ta coù theå taïo caùc ñieàu khieån “haïng nheï” trong Visual Basic 6.0. Ñaây laø caùc ñieàu khieån “Windowless” toán ít taøi nguyeân heä thoáng höon caùc ñieàu khieån khaùc. Ñeå xaùc ñònh moät ñieàu khieån coù phaûi “Windowless” hay khoâng Visual Basic 6.0 cung caáp thuoäc tính môùi HasDC.
Add-in laø coâng cuï Visual Basic maø caùc laäp trình vieân coù theå laäp trình ñeå taïo cho caùc laäp trình vieân khaùc. Nhöng Add-in ñöôïc vieát trong Visual Basic chæ coù theå thi haønh trong IDE cuûa VB. Trình taïo öùng duïng Application Wizard, trình bieåu maãu döõ lieäu ( Data Forms Wizard ) laø nhöõng phaàn theâm môùi.
Moät soá Wizard / Add-in duøng trong moïi phieân baûn nhö :
Trình ñoùng goùi vaø trieån khai töï ñoäng ( Package and development Wizard ) coâng duïng laø chuaån bò vaø trieån khai öùng duïng cho caùc maùy ñeå baøn hoaëc duøng qua maïng.
Trình taïo öùng duïng töï ñoäng (Application Wizard ): Khôûi taïo khung söôøn cho öùng duïng. Noù töï ñoäng theâm menu, thanh coâng cuï, taäp tin taøi nguyeân, caùc ñieàu khieån ActiveX vaø ñieàu khieån döõ lieäu.
Trình quaûn lyù töï ñoäng ( Wizard Manager ): toå chöùc caùc trình töï ñoäng khaùc nhau ñeå coù theå truy caäp töø trong IDE.
Moät soá Wizard / Add-in duøng trong phieân baûn Enterprise vaø Proffessional nhö:
Trình ñoái töôïng döõ lieäu töï ñoäng ( Data Object Wizard): Taïo caùc ñoái töôïng döõ lieäu lieân keát vôùi caùc ñieàu khieån döõ lieäu vaø caùc ActiveX hieäu chænh.
Tieän ích xaây döïng lôùp ( Class builder Ultility ): duøng taïo giao dieän caùc lôùp hieåu chænh.
Trình thanh coâng cuï töï ñoäng (toolBar Wizard): Duøng giao dieän taïo thanh coâng cuï cho bieåu maãu.
Trình bieåu maãu döõ lieäu töï ñoäng(Data Form Wizard): Taïo bieåu maãu chöùa caùc ñieàu khieån tham chieáu ñeán döõ lieäu trong moät CSDL.
Trình thieát keá Add-in (Add-in Designer) : Taïo caùc Add-in hieäu chænh cuûa VB.
Trình trang thuoäc tính töï ñoäng( Property page Wizard): Taïo hôïp thoaïi thuoäc tính cho caùc ñieàu khieån ActiveX töï taïo.
Trình gôõ roái T-SQL (T- SQL Debugger): Giuùp gôõ roái khi vieát caùc CSDL cuûa SQL Server.
Trình duyeät API Viewer: Giuùp tra cöùu caùc khai baùo haøm, haèng, kieåu cuûa caùc Window APIs.
Trình giao dieän ñieàu khieån ActiveX (ActiveX control interface Wizard) : Taïo caùc ñieàu khieån ActiveX.
3.3. Laøm vieäc trong moâi tröôøng laäp trình.
Tìm hieåu caùc thaønh phaàn cuûa IDE
Ñònh nghóa IDE : IDE laø teân vieát taét cuûa moâi tröôøng phaùt trieån tích hôïp ( Integrated Development Enviroment). IDE laø nôi taïo ra caùc chöông trình Visual Basic, laø nôi taäp trung caùc menu, thanh coâng cuï vaø caùc cöûa soå ñeå ta thao taùc treân chuùng. Moãi thaønh phaàn cuûa IDE coù caùc tính naêng aûnh höôûng ñeán hoaït ñoäng laäp ttrình khaùc nhau.
Thanh menu cho pheùp baïn thao taùc treân toaøn boä öùng duïng, thanh coâng cuï cho pheùp thao taùc, truy caäp caùc chöùc naêng cuûa thanh menu qua caùc nut treân thanh coâng cuï.
Caùc bieåu maãu (Form) laø khoái xaây döïng chính cuûa chöông trình Visual Basic, chuùng xuaát hieän trong caùc cuûa soå Form. Chuùng ta coù theå theâm caùc coâng cuï ñieàu khieån vaøo bieåu maãu cuûa caùc ñeà aùn( Project).
Project Explorer hieån thò caùc ñeà aùn baïn ñang laøm cuõng nhö caùc thaønh phaàn khaùc cuûa ñeà aùn, baïn coù theå duyeät, caøi ñaët caùc thuoäc tính cuûa ñieàu khieån, bieåu maãu vaø module trong cuûa soå Properties.
Cuoái cuøng baïn xem xeùt moät hoaëc nhieàu bieåu maãu treân maøn hình thoâng qua cuûa soå Form Layout.
Söû duïng moät soá thanh coâng cuï trong IDE
Chuùng ta coù theå theâm vaø xoaù caùc thanh coâng cuï trong IDE cuûa Visual Basic: Thanh coâng cuï laø taâp hôïp caùc nuùt baám mang bieåu töôïng chöùa trong moät thanh thöôøng ñaët döôùi thanh menu. Caùc nuùt baám naøy phaûi ñaûm baûo caùc chöùc naêng thoâng duïng trong caáu truùc cuûa thanh menu cuûa Visual Basic. Thanh coâng cuï raát höõu ích vaø tieát kieäm thôøi gian ñeå ta choïn qua caùc muïc ôû menu con, ta click vaøo moät nuùt naøo ñoù treân thanh coâng cuï ñeå goïi moät chöùc naêng naøo ñoù treân thanh menu.
Söû duïng thanh coâng cuï Debug : Thanh coâng cuï Debug duøng ñeå kieåm tra chöông trình vaø giaû quyeát moät soá loõi coù theå xaõy ra. Khi gôõ roái chöông trình ta laøm moät soá vieäc nhö chaïy töøng doøng chöông trình, kieåm tra caùc giaù trò bieán, hoaëc döøng chöông trình taïi moät ñieåm nghi ngôø naøo ñoù.
Söû duïng thanh coâng cuï Edit : Thanh coâng cuï Edit ñöôïc duøng ñeå vieát chöông trình trong caùc cöûa soå code. Noù bao goàm ñaày ñuû tính naêng coù ôû menu Edit. Moät tính naêng lyù thuù cuûa IDE laø thanh coâng cuï Edit coù chöùc naêng complete Word, töï ñoäng hoaøn taát caùc töø khoaù, noù giuùp cho ta traùnh ñöôïc caùc loãi cuù phaùp do goõ sai chính taû.
Thanh coâng cuï Form Editor duøng ñeå keùo giaõn, di chuyeån vaø saép xeáp caùc ñieàu khieån treân bieåu maãu, noù coù tính naêng töông töï nhö menu Format. Thuoäc tính ZOrder cuûa ñieàu khieån cho pheùp ñieàu khieån naøo coù theå naèm leân treân ñieàu khieån naøo, ñieàu khieån coù ZOrder baèng khoâng luoân naèm ôû beân treân.
Söû duïng thanh coâng cuï chuaån ( Standard )laø thanh coâng cuï chính trong IDE, noù cung caáp nhieàu tính naêng trong menu File, Project, Debug vaø Run.
Theâm caùc ñieàu khieån vaøo thanh coâng cuï
Hôïp coâng cuï laø baûng chöùa caùc ñieàu khieån vaø ta thieát keá giao dieän baèng caùch choïn caùc maãu ñieàu khieån vaø ñöa chuùng vaøo bieåu maãu.
Moät soá ñieàu khieån coù saún trong VB ta khoâng theå gôõ boû khoûi hoäp coâng cuï goïi laø caùc ñieàu khieån noäi taïi (intrinsic). Moät soá naèm ngoaøi VB chöùa trong caùc taäp tin coù phaàn môû roäng laø .OCX. Nhöõng ñieàu khieån naøy coù theå ñöôïc theâm vaøo hoaëc gôõ boû khoûi hoäp coâng cuï.
Quaûn lyù öùng duïng vôùi Project Explorer
Project Explorer trong VB 6.0 giuùp ta ñònh höôùng vaø quaûn lyù nhieàu döï aùn, noù cho pheùp toå chöùc nhieàu döï aùn chung trong moät nhoùm goïi laø Project groups. Ta coù theå löu taäp hôïp caùc ñeà aùn thaønh moät taäp tin nhoùm ñeà aùn vôùi phaàn môû roäng laø .vbg.
Project Explorer coù caáu truùc caây phaân caáp, caùc ñeà aùn naèm ôû phaàn treân cuûa caây vaø caùc boä phaän cuûa ñeà aùn chöùa trong phaàn döôùi caây. Khi chuùng ta caàn thao taùc treân thaønh phaàn naøo cuûa ñeà aùn ta chæ vieäc choïn phaàn aáy vaø xem cuûa soå Form hoaëc cuûa soå Code cuûa noù.
Ñaëc bieät noù voâ cuøng höõu ích cho chuùng ta trong khi xaây döïng nhieàu döï aùn lôùn.
Cöûa soå Properties:
Moãi thuoäc tính trong cöûa soå coù theå coù moät hoaëc nhieàu giaù trò. Noù giuùp baïn xem xeùt söûa ñoåi vaø ñieàu khieån caùc thuoäc tính cuûa ñieàu khieån ActiveX trong chöông trình.
Hieån thò trong IDE
Ta coù theå hieån thò IDE cuûa Visual Basic baèng hai caùch : MDI vaø SDI.
MDI laø giao dieän ña taøi lieäu, cho pheùp ta hieån thò taát caû caùc cöûa soå thaønh phaàn trong IDE nhö laø cöûa soå ñöôïc chöùa ñöïng trong cöûa soå meï.
Traùi laïi vôùi giao dieän SDI caùc cöûa soå thaønh phaàn hieån thò moät caùch ñoäc laäp nhau. Khoâng coù cöûa soå chính ñeå chöùa caùc cöûa soå thaønh phaàn.
Trôï giuùp
Khoâng chæ laøm chuû ngoân ngöõ laäp trình VB, baïn caàn phaûi caàn söû duïng thuaàn thuïc moâi tröôøng VB cuõng nhö hieåu caùc thoâng ñieäp maø VB göûi ra. Mircosoft ñaõ cung caáp moät trong nhöõng heä thoáng trôï giuùp toát nhaát cho coâng cuï phaùt trieân öùng duïng.
Nhöõng trôï giuùp nhaïy vôùi ngöõ caûnh ( Context-sensitive help) : taïi vò trí baát kyø trong VB baïn nhaán F1, hoaëc nuùt trôï giuùp. Noù seõ kích hoaït heä thoáng trôï giuùp cuûa Visual Basic, nôi coù theå giaûi thích cuõng nhö ñöa ra caùc lôøi khuyeân vaø caùc ñoaïn chöông trình maãu coù lieân quan.
Nhöõng ai quen duøng Windows, chaéc chaén cuõng bieát qua trôï giuùp caûm ngöõ caûnh. VB ñöôïc hoå trôï vôùi heä thoáng thö vieän MSDN ñöôïc söû duïng roäng raõi cho caùc öùng duïng cuûa Microsoft ñeå cung caáp, truy caäp ñeán coâng cuï höôùng daãn söû duïng caùc saûn phaåm tröïc tuyeán.
3.4. Giôùi thieäu veà thuoäc tính, phöông thöùc, söï kieän.
Visual Basic laø moät ngoân ngöõ laäp trình hoå trôï höôùng ñoái töôïng (Object-Oriented Programming). Trong laäp trình höôùng ñoái töôïng , laäp trình vieân chia nhoû caùc coâng vieäc thaønh caùc ñoái töôïng. Töøng ñoái töôïng coù ñôøi soáng rieâng cuûa noù, coù nhöõng ñaëc ñieåm goïi laø thuoäc tính (Properties), coù nhöõng chöùc naêng rieâng bieät goïi laø phöông thöùc ( methods).
Thuoäc tính.
Coù theå hieåu noâm na laø thuoäc tính moâ taû ñoái töôïng. Moãi ñoái töôïng ñeàu coù thuoäc tính moâ taû rieâng. Nhöng nhìn chung caùc ñoái töôïng ñeàu coù nhöõng thuoäc chính chung nhö :
Left : vò trí canh traùi,
Right : vò trí canh phaûi,
Height :chieàu cao cuûa ñoái töôïng ñieàu khieån,
Width: chieàu roäng cuûa ñoái töôïng,
Enable : Coù giaù trò logic ( True/False) quyeát ñònh ngöôøi söû duïng coù theå laøm vieäc vôùi caùc ñoái töôïng naøy khoâng.
Ngoaøi ra coøn raát nhieàu thuoäc tính khaùc tuyø theo töøng ñoái töôïng ñieàu khieån.
Phöông thöùc.
Phöông thöùc laø nhöõng ñoaïn chöông trình chöùa trong ñieàu khieån, cho ñieàu khieån bieát caùch thöïc hieän coâng vieäc naøo ñoù. Töông töï nhö thuoäc tính, moãi ñoái töôïng ñieàu khieån cuõng coù caùc phöông thöùc khaùc nhau, nhöng cuõng coù caùc phöông thöùc raát thoâng duïng cho haàu heát caùc ñoái töôïng. Ñoù laø:
Move : thay ñoåi vò trí cuûa moät ñoái töôïng theo yeâu caàu cuûa chöông trình.
Drag: thi haønh hoaït ñoäng keùo thaû cuûa ñoái töôïng.
SetFocus: cung caáp taàm ngaém cho ñoái töôïng ñöôïc chæ ra trong leänh goïi phöông thöùc.
ZOder : qui ñònh thöù töï xuaát hieän cuûa caùc ñoái töôïng treân maøn hình.
Söï kieän.
Neáu nhö thuoäc tính moâ taû ñoái töôïng, phöông thöùc chæ ra caùch thöùc ñoái töôïng haønh ñoäng thì söï kieän laø nhöõng phaûn öùng cuûa ñoái töôïng. Töông töï nhö thuoäc tính vaø phöông thöùc, söï kieän cuõng coù ñaëc tröông ôû töøng ñoái töôïng ñieàu khieån. Nhöng nhöõng söï kieän thöôøng gaëp nhaát cuûa caùc ñoái töôïng laø:
Change: Ngöôøi söû duïng söûa ñoåi chuoãi kyù töï trong hoäp keát hôïp ( combobox) hoaëc hoäp vaên baûn (TextBox).
Click : Ngöôøi söû duïng söû duïng caùc phím cuûa chuoät ñeå click leân caùc ñoái töôïng.
Dblick : Ngöôøi söû duïng söû duïng phím cuûa chuoät ñeå nhaáp ñuùp leân caùc ñoái töôïng.
DragDrop : Ngöôøi söû duïng keùo reâ moät ñoái töôïng sang ñoái töôïng khaùc.
DragOver: Ngöôøi söû duïng keùo reâ moät ñoái töôïng ngang qua moät ñieàu khieån khaùc.
GotFocus: Ñöa moät ñoái töôïng vaøo taàm ngaém cuûa ngöôøi söû duïng.
KeyDown: Ngöôøi söû duïng nhaán moät nuùt treân baøn phím khi moät ñoái töôïng ñang trong taàm ngaém.
KeyPress: Ngöôøi söû duïng nhaán vaø thaû moät nuùt treân baøn phím khi moät ñoái töôïng ñang trong taàm ngaém.
KeyUp: Ngöôøi söû duïng thaû moät nuùt treân baøn phím khi moät ñoái töôïng ñang trong taàm ngaém.
LostFocus: Ñöa moät doái töôïng ra khoûi taàm ngaém.
MouseDown: Ngöôøi söû duïng nhaán moät nuùt chuoät baát kyø trong khi con troû chuoät ñang naèm treân moät ñoái töôïng.
MouseMove : Ngöôøi söû duïng di chuyeån con troû ngang qua moät ñoái töôïng.
MouseUp : Ngöôøi söû duïng thaû nuùt chuoät trong khi con troû chuoät ñang naèm treân moät ñoái töôïng.
3.5. Khaû naêng söû duïng caùc DLL vaø Windows API.
Windows cung caáp voâ soá caùc haøm goïi, döôùi daïng thö vieän leân keát ñoäng (Dynamic Link Libraries ). Trong Visual Basic 6.0 coøn coù caùc tieän ích goïi ngöôïc cuûa DLL ( DLL Callback Facilities ), nghóa laø thay vì ta goïi chöông trình trong API, noù cho pheùp ta goïi moät API maø baûn thaân noù coù theå goïi ngöôïc veà chöông trình cuûa ta nhö laø moät phaàn chöông trình cuûa noù vaäy.
Giôùi thieäu veà thö vieän lieân keát ñoäng (DLL)
Ñoái vôùi caùc ngoân ngöõ laäp trình coå ñieån nhö C, khi bieân dòch chöông trình, ta coù moät chöông trình .EXE duy nhaát coù theå thi haønh maø khoâng duøng baát kyø taäp tin naøo khaùc, coøn taäp tin .vbp cuûa Visual Basic khoâng nhö theá noù phaûi chaïy trong moâi tröôøng Visual Basic.
Coù 2 loaïi thö vieän lieân keát : thö vieän lieân keát tónh (SLL) vaø thö vieän lieân keát ñoäng (DLL).
Lieân keát tónh : Cung caáp moät keát noái beàn vöõng giöõa chöông trình vaø module vieát saún luùc thieát keá, töông töï nhö vieát thuû tuïc trong Visual Basic vaø goïi thuû tuïc ñoù, nhöng chæ khaùc laø lieân keát tónh chöùa beân ngoaøi Visual Basic. Tuy nhieân khi söû duïng caàn phaûi copy ñoaïn chöông trình vieát saún cuûa lieân keát tónh vaøo taäp tin chöông trình khi bieân dòch. Töø ñoù trôû ñi noù trôû thaønh moät phaàn cuûa chöông trình vieát saún vaø gaén chaët vôùi chöông trình cuûa ta.
Lieân keát ñoäng : Laø giaûi phaùp linh hoaït hôn lieân keát tónh, taäp tin thö vieän beân ngoaøi chöông trình khoâng bò raøng buoäc vôùi chöông trình. Noù chöùa moät nôi sao cho taäp tin EXE coù theå tìm ra vaø göûi thoâng ñieäp cho noù. Khi thi haønh caùc thoâng ñieäp naøy laø caùc cuoäc goïi ñeán caùc haøm/ thuû tuïc, yeâu caàu phaàn naøo ñoù cuûa DLL ñöôïc thi haønh.
Caùc DLL cuûa Visual Basic naèm trong thö muïc Windows \ System \
Giôùi thieäu veà caùc DLL cuûa Windows.
KERNEL32 : Laø DLL chính, ñaûm nhieäm quaûn lyù boä nhôù, thöïc hieän chöùc naêng ña nhieäm vaø nhöõng haøm aûnh höôûng tröïc tieáp ñeán hoaït ñoäng cuûa Windows.
USER32 : Laø thö vieän quaûn lyù Windows. Thö vieän naøy chöùa caùc haøm xöû lyù menu, ñònh giôø, truyeàn tin, taäp tin vaø nhieàu phaàn khoâng ñöôïc hieån thò khaùc cuûa Windows.
GDI32 : Laø thö vieän chöùa giao dieän thieát bò ñoà hoaï (Graphics Device Interface) cung caáp caùc haøm veõ treân maøn hình, cuõng nhö kieåm tra phaàn bieåu maãu naøo caàn veõ laïi.
WINNM: cung caáp caùc haøm Multimedia ñeå xöû lyù aâm thanh, nhaïc, video, thôøi gian thöïc, laáy maãu, vv… Ñaây laø thö vieän 32 bit coøn thö vieän 16 bit töông öùng teân laø MMSYSTEM.
Theá maïnh cuûa DLL.
Nhaát quaùn : Ngöôøi söû duïng öa chuoäng Windows vì ña soá ñieàu coù moät giao dieän phoå bieán cho moïi öùng duïng, nghóa laø coù chöông trình chung ñeå taïo ra chuùng.
Deã baûo trì : Nhöõng thay ñoåi hoaëc boå sung neáu coù seõ bieåu hieän treân moïi öùng duïng.
Taäp tin .EXE nhoû hôn : Do moät phaàn coâng vieäc chöùa ñöïng ôû nôi khaùc vaø khoâng gaén keát “cöùng nhaéc” nhö lieân keát tónh, kích côõ taäp tin nhoû hôn. Tuy nhieân DLL coøn chöùa nhieàu thaønh phaàn khaùc chöù khoâng chæ nhöõng gì chöông trình cuûa ta caàn.
Caáu truùc cuûa Windows : DLL laø neàn taûng thieát keá cuûa Windows. Windows thöïc chaát laø taäp hôïp caùc DLL ñeå caùc öùng duïng khaùc nhau coù theå duøng chung. Beân trong caùc DLL laø haøng traêm, ngaøn caùc haøm vaø thuû tuïc. Ta goïi chung laø Windows API.
Giôùi thieäu veà WIN API
Giao dieän laäp trình öùng duïng ( Application Programmer’s Interface ) laø taäp hôïp caùc haøm coù saún cuûa Windows, chuùng gaàn guûi vôùi ngoân ngöõ C/ C++ hôn. Visual Basic ñöôïc thieát keá theo kieåu che bôùt caùc coâng vieäc beân döôùi heä thoáng. Phaàn lôùn caùc cuoäc goïi ñeán haøm API ñöôïc loàng trong caùc daïng leänh cuûa Visual Basic, bao goàm caùc töø khoaù, phöông thöùc vaø thuoäc tính. Chuùng seõ ñöôïc thoâng dòch thaønh WinAPI vaø chuùng ta vaän duïng caùc theá maïnh hoå trôï cuûa chuùng.
Lôùp boïc API vaø caùc ñieàu khieån hieäu chænh : Ñieàu khieån hieäu chænh (OCX hay ActiveX) baûn thaân chuùng laø nhöõng lôùp boïc API, chuùng chuyeån giao chuyeån giao caùc chöùc naêng theo kieåu Visual Basic moät caùch thaân thieän. Caùc ñieàu khieån ActiveX vaø OLE Automation Servers ñöa chöông trình vaøo caùc ñeà aùn maø khoâng caàn coù caùc DLL thöïc söï.
Caùch goïi haøm API.
Goïi haøm API trong Visual Basic khoâng khaùc vôùi goïi haøm/ thuû tuïc trong module cuûa ñeà aùn.
Ví duï thuû tuïc goïi sau:
Public Declare Function Flash Lib “User32” Alias “FlashWindow” (ByVal hWnd as Long, Byval Invert As Long ) as Long.
Khai baùo cho moät cuoäc goïi API :
Tröôùc khi duøng haøm cuûa DLL, ta caàn khai baùo haøm ñoù cho Visual Basic hieåu, Visual Basic caàn bieát:
Teân haøm hoaëc thuû tuïc.
Teân taäp tin DLL chöùa noù.
Tham soá truyeàn.
Kieåu döõ lieäu traû veà neáu laø haøm.
Töø khoaù Declare baùo cho VB bieát ñaây laø moät haøm cuûa DLL, sau Declare laø töø khoaù Sub hoaëc Function cho bieát ñaây laø thuû tuïc hay haøm. Töø khoaù Lib cho bieát teân cuûa DLL ñang chöùa haøm hoaëc thuû tuïc maø ta goïi. Töø khoaù Alias cho bieát teân thöïc söï cuûa thuû tuïc hoaëc haøm trong thö vieän. Noù coù theå khaùc vôùi teân ta khai baùo tröôùc töø khoaù Lib. Cuoái cuøng laø khai baùo caùc tham soá truyeàn, cuøng caùc kieåu döõ lieäu traõ veà.
3.6. Thieát laäp baùo caùo vaø truy xuaát thoâng tin.
Thieát laäp baùo caùo treân cô sôû döõ lieäu khoâng chæ laø hieån thò cô sôû döõ lieäu töø döõ lieäu maø noù coøn lieân quan ñeán moät soá hoaït ñoäng khaùc treân döõ lieäu. Sau ñaây toâi xin giôùi thieäu veà moät soá coâng cuï laäp baùo cao nhö Data Report, MS Access, Crystal Report.
3.6.1. Söû duïng moät soá coâng cuï ñeå laäp baùo caùo trong Visual Basic.
Söû duïng thieát keá DATAREPORT:
Ñaây laø ñieåm noåi baäc trong VB 6, thieát keá Datareport laø caùch tröïc quan ñeå taïo baùo caùo trong moâi tröôøng phaùt trieån VB, noù cung caáp caùc chöùc naêng heát söùc cô baûn nhöng laïi laïi deã duøng. Caùc ñieàu khieån Report bao goàm :
caùc ñieàu khieån nhaõn,
ñieàu khieån hôïp vaên baûn,
ñieàu khieån aûnh,
ñieàu khieån ñoaïn thaúng vaø ñieàu khieån hình daïng,
ñieàu khieån haøm cho pheùp cheøn caùc tính toaùn toùm taét vaøo baùo caùo.
Chuùng ta coù theå xem baùo caùo trong cheá ñoä Print Preview baèng caùch thi haønh phöông thöùc Show
Söû duïng MS Access ñeå laäp baùo caùo:
MS Access cho pheùp vieát caùc baùo caùo cô sôû döõ lieäu. Noù hoå trôï giao dieän deã duøng vaø tröïc quan. Noù cho pheùp saép xeáp vaø phaân nhoùm cuõng nhö söû duïng caùc hieäu chænh trong baùo caùo. Hai kyõ thuaät ñeå thöïc hieän laø:
Söû duïng Automation ñeå thi haønh baùo caùo Access.
Söû duïng VSREPORTS ñeå thi haønh baùo caùo Access.
Söû duïng CRYSTAL REPORT ñeå laäp baùo caùo:
Ta khoâng theå taïo baùo caùo baèng chöông trình maø thay vaøo ñoù ta duøng Crystal Report ñeå xaây döïng baùo caùo. Sau khi xaây döïng xong baùo caùo ta löu noù vaø phaân phaùt cuøng caùc öùng duïng cho ngöôøi söû duïng.
3.6.2. Söû duïng caùc coâng cuï in aán trong Visual Basic.
Söû duïng ñoái töôïng Printer.
Ta coù theå duøng ñoái töôïng Printer cuûa Visual Basic ñeå in döõ lieäu töø öùng duïng. Tuy nhieân caùch naøy ñoøi hoûi laäp trình nhieàu vaø khoâng linh hoaït trong nhöõng tröôøng hôïp caàn kieåm soaùt keát quaû in aán. Khi söû duïng ñoái töôïng printer ta caàn thöïc hieän caùc böôùc sau:
Xaùc ñònh heä toaï ñoä ta seõ duøng vôùi ñoái töôïng Printer.
Taïo caùc caùch boá trí baùo caùo.
Vieát chöông trình taïo ñoái töôïng Recordset duøng baát cöù thö vieän truy caäp cô sôû döõ lieäu naøo tuyø thích.
Laëp xuyeân qua caùc maãu tin ñeå traû veà caùc ñoái töôïng Recordset, göûi döõ lieäu ñeán ñoái töôïng Printer duøng caùc thuoäc tính vaø caùc phöông thöùc cuûa noù.
Ñoái töôïng Printer ñöa ra moät soá thuoäc tính vaø caùc phöông thöùc hoå trôï vieäc theå hieän trang in vaø caùc taùc vuï ñieàu khieån nhö :
Thuoäc tính CurentX, curentY : kieåm soaùt vò trí hieän haønh treân trang in.
Thuoäc tính Font laø ñoái töôïng ñieàu khieån caùc thuoäc tính cuûa vaên baûn chöùa trong trang in.
Phöông thöùc Print : trình baøy vaên baûn treân trang in.
Phöông thöùc Newpages cheøn moät pheùp ngaét trang vaøo taùc vuï in, thuoäc tính page traû veà trang in hieän haønh cuûa taùc vuï in, phöông thöùc KillDoc xoaù boû moät taùc vuï in.
Phöông thöùc ñoà hoaï nhö Line, Point, Circle.
Phöông thöùc EnDoc: göûi toaøn boä taùc vuï in cho maùy in. Thi haønh phöông thöùc naøy ôû cuoái taùc vuï in söû duïng ñoái töôïng Printer.
Söû duïng VSVIEW cuûa VIDEOSOFT ñeå laäp baùo caùo vaø in baûng in vôùi ñieàu khieån VsPrinter:
Thieáu soùt cuûa ñoái töôïng Printer laø tröôùc khi in ta khoâng bieát ñöôïc baùo caùo seõ theå hieän nhö theá naøo, hay thaäm chí khoâng bieát baùo caùo coù bao nhieâu trang in do ñoù ta neân duøng coâng cuï cung caáp nhieàu tieän ích hôn laø vsPrinter.
VsPrinter raát thích hôïp ñeå in baûng CSDL bôûi vì noù hoå trôï roõ raøng cho vieäc in döõ lieäu theo ñònh daïng doøng – coät. Ta coù theå in döõ lieäu trong baûng baèng caùch gaùn döõ lieäu cho thuoäc tính Table cuûa ñieàu khieån.
Ñeå taïo baûng vsPrinter, tröôùc heát caàn taïo ra moät chuoåi chöùa thoâng tin ñònh daïng caùch thöùc in baûng chöùa caùc thoâng tin ñaày ñuû veà caùch boá trí vaên baûn.
4. KHAÛ NAÊNG KEÁT NOÁI VÔÙI CÔ SÔÛ DÖÕ LIEÄU CUÛA VISUAL BASIC.
Hình 2: Minh hoaï khaû naêng keát noái döõ lieäu cuûa VB vôùi CSDL.
Data
ActiveX .EXE
.DLL
Midder Tier
Data
Source
Form
Client
DHTML
Report
Code
Data binding
Remoting
Data Access ADO, RDO, DAO
Class Module, Data Enviroment
Creatable Recordsets, ADO Data Control , Intrinsic Data Control
DCOM, Remotables,ADO Recordsets, Remoting UDTs
Microsoft Transaction
Server
Microsoft Visual Database Tool (Dataview)
Söû duïng Visual Basic 6.0 baïn coù theå taïo caùc thaønh phaàn goùi goïn töøng böôùc trong moät heä thoáng truy caäp döõ lieäu. Khôûi ñaàu vôùi data source, Microsoft Visual Data Tools (Vieäc truy caäp döõ lieäu thoâng qua cöûa soå Dataview) cung caáp cho baïn caùc khaû naêng ñeå xem vaø thao taùc treân caùc ñoá töôïng Table, views, Stored procedures, vaø caùc sô ñoà cô sôû döõ lieäu treân caùc heä thoáng SQL Server vaø Oracle.
Data Source vaø Data Controls :
Treân Client chuùng ta coù theå söû duïng coâng cuï Data Enviroment ñeå thöïc hieän vieäc taïo nhanh caùc keát noái ADO vaø caùc ñoái töôïng Command ñeå truy caäp döõ lieäu cuûa baïn. Data Enviroment coøn cung caáp theâm caùc giao tieáp laäp trình ñoäng cho pheùp truy caäp caùc ñoái töôïng döõ lieäu trong döï aùn cuûa baïn.
ADO Conrol veà baûn chaát beân trong cung töông töï nhö Data Control, ngoaïi tröø vieäc noù söû duïng ñoái töôïng ADO Recordset nhö laø moät Data Source cho caùc Controls vaø caùc ñoái töôïng trong Visual Basic.
Dynamic Data Binding:
Khaû naêng keát buoäc moät data source tôùi moät ñoái töôïng caàn döõ lieäu laø khaû thi ñoái vôùi Visual Basic 6.0. Taïi thôøi ñieåm thi haønh baïn coù theå thieát laäp thuoäc tính Data source cuûa ñoái töôïng caàn döõ lieäu (ví duï nhö ñoái töôïng DataGrid Control ) tôùi moät data source.
Theá maïnh cuûa Visual Basic laø khaû naêng hoå trôï vaø keát noái döõ lieäu. Visual Basic hoå trôï caùc kieåu truy caäp döõ lieäu nhö : DAO - ñoái töôïng truy caäp döõ lieäu, RDO – truy caäp döõ lieäu töø xa, ADO - caùc ñoái töôïng döõ lieäu ActiveX. Noù coøn coù khaû naêng keát noái vôùi döõ lieäu töø MS Access, SQL Server vôùi heä quaûn trò cô sôû döõ lieäu Oracle vaø moät soá heä quaûn trò cô sôû döõ lieäu khaùc.
Trong ñoà aùn toát nghieäp naøy toâi ñaõ caøi ñaët chöông trình treân ngoân ngöõ VB 6.0 vaø duøng heä quaûn trò CSDL SQL Server 7.0 qua phöông phaùp truy caäp ADO.
Sau ñaây toâi xin giôùi thieäu theâm veà kieåu truy caäp döõ lieäu ADO
Ñoái töôïng döõ lieäu ActiveX (Active X Data Object)
Sô ñoà kieán truùc cuûa ADO :
Connection
Command
Recordset
Errors
Fields
Parameters
Error
Parameter
Field
Khaùi nieäm veà ADO:
Laø caàu noái giöõa ñoái töôïng cung caáp döõ lieäu vaø ñoái töôïng söû duïng döõ lieäu thoâng qua caùc Data source ñaõ ñöôïc taïo cho vieäc söû duïng Microsoft ActiveX Data Objects (ADO), noù laø phöông phaùp toái öu nhaát ñeå truy caäp döõ lieäu cuûa Visual Basic trong nguoàn döõ lieäu baát kyø quan heä vaø khoâng quan heä. Truy nhieân caùc phöông phaùp khaùc nhö RDO, DAO vaãn coøn ñöôïc hoå trôï.
III. GIÔÙI THIEÄU VEÀ CAÙC HEÄ QUAÛN TRÒ CÔ SÔÛ DÖÕ LIEÄU SQL SERVER
1. Caáu truùc cô sôû döõ lieäu cuûa SQL Server 7.0.
SQL Server toå chöùc döõ lieäu löu trong Cô sôû döõ lieäu (CSDL) thaønh nhöõng thaønh phaàn logic. User laøm vieäc treân nhöõng thaønh phaàn logic naøy nhö baûng (table), view, procedure… Thaønh phaàn vaät lyù cuûa nhöõng file thì trong suoát (transparent), chæ coù ngöôøi quaûn lyù Cô sôû döõ lieäu môùi ñöôïc laøm vieäc treân ñoù.
SQL Server coù 4 cô sôû döõ lieäu heä thoáng ( master, msdb, model, temdb database ) vaø caùc cô sôû döõ lieäu cuûa user. Hình minh hoïa
Master database: Ghi laïi caáu hình heä thoáng cuûa SQL Server. Noù ghi laïi taát caû taøi khoaûn ñaêng kyù cuûa user vaø caáu hình heä thoáng, nhöõng file primary chöùa thoâng tin khôûi ñoäng cuûa Cô sôû döõ lieäu cuûa user, chöùa thoâng tin khôûi ñoäng cuûa SQL Server. Nhöõng thao taùc sau gaây ra nhöõng thay ñoåi trong master database: Taïo, thay ñoåi, xoùa cô sôû döõ lieäu,thay ñoåi transaction log. Theâm hay xoùa cuûa nhöõng sever söû duïng thuû tuïc heä thoáng nhö sp-addserver (theâm server) and sp-dropserver (boû server).
Temdb database : chöùa nhöõng baûng taïm vaø nhöõng stored procedure taïm. Nhöõng baûng taïm vaø nhöõng stored procedure cuûa user khi noái keát vaøo heä thoáng ñöôïc löu trong temdb database. Khi SQL khôûi ñoäng thì taát caû caùc baûng taïm vaø caùc stored procedure trong temdb database ñeàu maát.
Stored procedure : laø 1 taäp hôïp bieân dòch tröôùc cuûa nhöõng caâu leänh cuûa Transact-SQL ñöôïc löu vaø xöû lyù nhö 1 ñôn vò (unit). Stored procedure saün saøng cho vieäc quaûn lyù SQL Server vaø hieån thò thoâng tin cuûa cô sôû döõ lieäu, cuûa nhöõng ngöôøi söû duïng. SQL Server cung caáp nhöõng stored procedure goïi laø stored procedure heä thoáng.
Model database : ñöôïc duøng nhö 1 khuoân maãu cuûa CSDL trong heä thoáng. Khi taïo ra 1 CSDL thì phaàn ñaàu cuûa CSDL laø baûn sao cuûa model database, phaàn coøn laïi laø nhöõng trang troáng.
Msdb database : SQL Server Agent duøng msdb database ñeå laäp keá hoaïch alert, job. Alert laø 1 ñònh nghóa cuûa ngöôøi söû duïng ñaùp öùng 1 söï kieän cuûa SQL Server. Alert coù theå thöïc thi caû nhieäm vuï ñònh nghóa hoaëc gôûi e-mail ñeán 1 ngöôøi chæ ñònh. Job laø söï thöïc hieän 1 haønh ñoäng quaûn lyù chöùa 1 hoaëc nhieàu böôùc, thay theá cho thuaät ngöõ task cuûa SQL Server 6.5.
2. Caáu truùc cô sôû döõ lieäu vaät lyù.
a. Trang (page).
Ñôn vò cô baûn löu tröõ döõ lieäu laø trang (page). Trong SQL Server 7.0, 1 trang coù kích thöôùc 8MB, ta seõ coù 128 trang/1MB. 96 byte ñaàu cuûa moãi trang chöùa header cuûa trang goàm thoâng tin heä thoáng nhö loaïi trang, soá vuøng troáng cuûa trang.
Caáu truùc trang döõ lieäu : Caùc haøng döõ lieäu (data row) ñöôïc ñöa vaøo tuaàn töï ngay sau page header, row offset ñöôïc baét ñaàu töø cuoái trang, chæ ñeán data row vaø cho bieát byte baét ñaàu cuûa data row, kích thöôùc haøng toái ña laø 8060 byte.
b. Extent.
Extent laø ñôn vò cô baûn chæ vuøng löu baûng vaø index. Moãi extent goàm 8 trang lieân tuïc nhau. Coù 2 loaïi extent :
Mixed extent coù theå löu nhöõng ñoái töôïng khaùc nhau.
Uniform extent chæ coù theå löu 1 ñoái töôïng duy nhaát.
c. Nhöõng loaïi file trong CSDL : SQL Server coù 3 loaïi file:
Primary file : laø file baét ñaàu cuûa cô sôû döõ lieäu. Moãi cô sôû döõ lieäu chæ coù 1 file primary, teân file coù phaàn môû roäng laø .mdf
Secondary file : laø file löu nhöõng gì coøn laïi cuûa cô sôû döõ lieäu maø khoâng chöùa trong primary file, coù theå coù nhieàu file secondary, teân file coù phaàn môû roäng laø .ndf.
Log file : chöùa nhöõng thoâng tin transaction log, ñöôïc duøng ñeå khoâi phuïc cô sôû döõ lieäu, moãi cô sôû döõ lieäu coù ít nhaát 1 log file, teân file coù phaàn môû roäng laø .ldf.
File cuûa SQL Server coù 2 teân:
Logical_file_name: laø teân duøng trong nhöõng caâu leänh Transact_SQL.
Os_file _name: laø teân file vaät lyù, chæ roõ ñöôøng daãn cuûa file cô sôû döõ lieäu, ví duï: C:\Mssql7\Data\MyData1.mdf laø teân Os_file_name.
MyDB_primary laø teân logical_file_name, Nhöõng trang trong file ñöôïc ñaùnh soá baét ñaàu töø 0. Moãi file coù 1 soá ID. Moãi trang trong file goàm caû ID file vaø soá thöù töï trang trong file.
Ví duï: File primary coù kích thöôùc 4MB, vaø Secondary coù kích thöùôc 1 MB.
Trang ñaàu tieân trong moãi file laø trang header file chöùa thoâng tin veà thuoäc tính cuûa file. Trang thöù 9 trong primary file laø trang khôûi ñoäng cô sôû döõ lieäu chöùa thoâng tin veà thuoäc tính cuûa cô sôû döõ lieäu.
3. Lyù thuyeát moâ hình quan heä
a. Caùc khaùi nieäm cô baûn
Thöïc theå : laø moät ñoái töôïng cuï theå naøo ñoù
Thuoäc tính thöïc theå : Tính chaát xaùc ñònh thöïc theå
Lôùp thöïc theå : Caùc thöïc theå coù cuøng thuoäc tính
Thuoäc tính: Teân thuoäc tính, mieàn xaùc ñònh cuûa thuoäc tính
Löôïc ñoà quan he : goàm caùc thuoäc tính cuûa thöïc theå (teân, mieàn xaùc ñònh) cuøng vôùi caùc meänh ñeà raøng buoäc.
Löôïc ñoà cuûa moät quan heä : R== (A1: D1’ A2 : D2 ,……,An :Dn , M) trong ñoù: AI :Teân thuoäc tính, DI :Mieàn xaùc ñònh cuûa thuoäc tính, M : Meänh ñeà raøng buoäc.
b. Khaùi Nieäm phuï thuoäc döõ lieäu vaø caùc daïng chuaån
Moät thuoäc tính goïi laø phuï thuoäc vaøo caùc thuoäc tính khaùc khi giaù trò cuûa thuoäc tính naøy phuï thuoäc vaøo giaù trò cuûa thuoäc tính kia. Söï phuï thuoäc coù theå laø tröïc tieáp hay giaùn tieáp.
Moät quan heä bao giôø cuõng coù moät nhoùm thuoäc tính maø giaù trò cuûa chuùng qui ñònh giaù trò cuûa caùc thuoäc tính khaùc, nhoùm thuoäc tính ñoù goïi laø khoùa.
Vôùi moät quan heä tuøy vaøo caùc phuï thuoäc cuûa caùc thuoäc tính vaøo khoùa trong ñoù maø ta phaân chia caùc quan heä ñoù thaønh caùc daïng chuaån khaùc nhau.
Caùc daïng chuaån cô baûn:
Daïng chuaån 1
Daïng chuaån 2
Daïng chuaån 3
Caùc döõ lieäu löu giöõ döôùi daïng chuaån 3 traùnh ñöôïc hieän töôïng dö thöøa döõ lieäu, taïo cho döõ lieäu coù tính ñoäc laäp cao. Caùc quan heä neáu chöa ôû daïng chuaån 3 seõ ñöôïc phaân raõ thaønh caùc quan heä nhoû hôn ôû daïng chuaån 3.
c. Khaùi nieäm chæ daãn vaø khoùa chæ daãn
Ñeå coù theå tìm kieám thoâng tin nhanh theo moät tieâu chuaån naøo ñoù chuùng ta taïo ra caùc thoâng tin chæ daãn theo tieâu chuaån ñoù. Caùc thoâng tin chæ daãn laø caùc thoâng tin giuùp ta tìm kieám döõ lieäu nhanh. Caùc thoâng tin naøy goïi laø khoùa chæ daãn. Khoùa chæ daãn coù theå laø moät tröôøng, hoaëc nhieàu tröôøngï.
Vôùi caùch taïo ra khoùa chæ daãn theo tieâu chuaån naøo ñoù ta coù theå tìm kieám nhanh döõ lieäu theo tieâu chuaån ñoù.
CHÖÔNG IV
XAÂY DÖÏNG CHÖÔNG TRÌNH
I. Phaàn döõ lieäu :
Nhö ñaõ trình baøy trong chöông 2, phaàn phaân tích vaø thieát keá heä thoáng. Ta toå chöùc döõ lieäu thaønh 16 baûng döõ lieäu nhö treân.
Hình : Moâ hình vaät lyù döõ lieäu
II. Moät soá giao dieän chính :
1. Hình aûnh Form chính cuûa chöông trình:
2. Ñaây laø hình aûnh Menu giao dòch xuaát haøng:
3. Hình aûnh Form ñôn ñaët haøng :
4. Hình aûnh Form laäp phieáu xuaát haøng :
5. Hình aûnh Form laäp phieáu thu tieàn haøng :
III. Moät soá moâ ñun chính :
1. Moâ moâ ñun keát noái CSDL :
Public Function Ketnoi() As Boolean
On Error Resume Next
con.ConnectionTimeout = 5
'su dung sqloledb de ket noi toi sqlserver
' phuong thuc chuoi ket noi
con.ConnectionString = "PROVIDER=SQLOLEDB.1;server =(local)" &
";Database=dulieu1" & ";Trusted_Connection=yes"
'con.Properties("Prompt") = adPromptComplete
con.Open
End Function
2. Moâ ñun kieåm tra ngaøy thaùng nhaäp vaøo :
' Ham kiem tra ngay nhap vao
Public Function checkdate(strdate As String) As String
Dim temp As Integer
Dim strtemp As String
temp = 3
If IsNumeric(Left(strdate, 1)) Then ' Neu ky tu dau la so thi
If IsNumeric(Mid(strdate, 2, 1)) Then ' Neu ky tu thu hai la so thi
If Left(strdate, 2) <= 31 Then ' Neu gia tri 2 ky tu
' <=31 thi kiem tra dau "/"
mask1:
If Mid(strdate, temp, 1) = "/" Then
If IsNumeric(Mid(strdate, temp + 1, 1)) Then
If IsNumeric(Mid(strdate, temp + 2, 1)) Then
If Mid(strdate, temp + 1, 2) <= 12 Then
If Mid(strdate, temp + 3, 1) = "/" Then
strtemp = Left(strdate, temp + 3) ' Cat bo 6 ky tu dau
If IsDate(strdate) Then ' Chuyen phan con lai th nam
checkdate = strtemp & Format(strdate, "yyyy")
Else
GoTo msgdate
End If
End If
Else
GoTo msgdate
End If
Else
If Mid(strdate, temp + 2, 1) = "/" Then
strtemp = Left(strdate, temp + 2)
If IsDate(strdate) Then
checkdate = strtemp & Format(strdate, "yyyy")
Else
GoTo msgdate
End If
End If
End If
Else
GoTo msgdate
End If
Else
GoTo msgdate
End If
Else
GoTo msgdate
End If
Else
If Mid(strdate, 2, 1) = "/" Then
temp = 2
GoTo mask1
Else
GoTo msgdate
End If
End If
Else
msgdate:
checkdate = "1"
End If
End Function
3. Moâ ñun löu döõ lieäu xuaát haøng:
Public Sub Luudl()
On Error GoTo error1
Dim rs As New ADODB.Recordset
Dim cmd As New ADODB.Command
Dim str As String
If Trim(txtmapnx) = "" Or Trim(txtngaylappnx) = "" Or Trim(Combomaddh.Text) = "" Or Trim(txtngaynx) = "" Or Trim(txtngayhtt) = "" Or Trim(Combomahang.Text) = "" Or Trim(txtsoluongnx) = "" Or Trim(txtdongianx) = "" Then
MsgBox "Chu y: Phai nhap day du thong tin truoc khi luu!", vbOKOnly + vbExclamation, "Thong bao"
txtmapnx.SetFocus
Exit Sub
End If
'Neu kiem tra ma khach hang co bat dau bang chu 'K' hay khong
If Left(Trim(txtmapnx), 1) "X" Then
MsgBox "Chu y: Ma phieu xuat hang phai bat dau boi 'X ...' !", vbOKOnly + vbExclamation, "Thong bao"
txtmapnx.SetFocus
Exit Sub
End If
'Tim xem da ton tai Maduong nay trong Table duong hay chua?
Set cmd.ActiveConnection = con
str = "Select NXHANG.mapnxh, NXHANG.maddh, NXHANG.makho, NXHANG.ngaynxh, NXHANG.ngayhtt, NXHANG.ngaylappnx from NXHANG where mapnxh like 'X%' and mapnxh = '" & Trim(txtmapnx) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Neu chua ton tai
Set rs = Nothing ' Dong record lai
toithieu = 0 'Xoa gia tri ban dau
toida = 0 'Xoa gia tri ban dau
Set cmd.ActiveConnection = con
str = "select MATHANG.mahang, MATHANG.sltontt, MATHANG.sltontd from MATHANG where MATHANG.mahang ='" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = False Then ' Neu da ton tai, chac chan co
toithieu = rs!sltontt
toida = rs!sltontd
Set rs = Nothing
End If
Set cmd.ActiveConnection = con
str = "select CTMATHANG.mahang, CTMATHANG.soluongton from CTMATHANG where CTMATHANG.mahang ='" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = False Then ' Neu da ton tai
sltontam = rs!soluongton - Val(txtsoluongnx)
If sltontam < toithieu Then
MsgBox "So luong hang ton duoi muc toi thieu. Can phai nhap them truoc da.", vbOKOnly + vbExclamation, "Thong bao"
txtsoluongnx.SetFocus
Me.MousePointer = 0
Set rs = Nothing
Exit Sub
Else ' Neu khong duoi muc ton toi thieu, cap nhat SL
Set rs = Nothing
Set cmd.ActiveConnection = con 'Mo lai de luu
str = "Select NXHANG.mapnxh, NXHANG.maddh, NXHANG.makho, NXHANG.ngaynxh, NXHANG.ngayhtt, NXHANG.ngaylappnx from NXHANG where mapnxh like 'X%' and mapnxh = '" & Trim(txtmapnx) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Neu chua ton tai, chac chan chua co
rs.AddNew
rs!mapnxh = Trim(txtmapnx)
rs!ngaylappnx = Trim(txtngaylappnx)
rs!maddh = Trim(Left(Combomaddh.Text, 5))
rs!makho = Trim(Left(Combomakho.Text, 5))
rs!ngaynxh = Trim(txtngaynx)
rs!ngayhtt = Trim(txtngayhtt)
rs.Update
Set rs = Nothing ' Dong record lai
End If
Set cmd.ActiveConnection = con
str = "Select DONGNXHANG.mapnxh, DONGNXHANG.mahang, DONGNXHANG.soluongnxh, DONGNXHANG.dongianxh from DONGNXHANG where mapnxh like 'X%' and mapnxh = '" & Trim(txtmapnx) & "' and mahang = '" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Neu chua ton tai
rs.AddNew
rs!mapnxh = Trim(txtmapnx)
rs!mahang = Trim(Left(Combomahang.Text, 4))
rs!soluongnxh = Trim(txtsoluongnx)
rs!dongianxh = Trim(txtdongianx)
rs.Update
Set rs = Nothing
End If
'Chi tiet mat hang duoc cap nhat sau cung
Set rs.ActiveConnection = con 'Cap nhat phai nhu vay
str = "Update CTMATHANG set soluongton ='" & sltontam & "' where mahang ='" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
sltontam = 0 ' Xoa
Set rs = Nothing 'Dong ban ghi lai
End If
Else ' Neu chua co (chua xuat lan nao)
sltontam = Val(txtsoluongnx) ' Kiem tra vuot Sltontd
If sltontam < toithieu Then
MsgBox "So luong hang ton duoi muc toi thieu. Can phai nhap them truoc da.", vbOKOnly + vbExclamation, "Thong bao"
txtsoluongnx.SetFocus
Me.MousePointer = 0
Set rs = Nothing
Exit Sub
Else ' Khong duoi SLtontt, tao moi
Set rs = Nothing
Set cmd.ActiveConnection = con 'Mo lai de luu
str = "Select NXHANG.mapnxh, NXHANG.maddh, NXHANG.makho, NXHANG.ngaynxh, NXHANG.ngayhtt, NXHANG.ngaylappnx from NXHANG where mapnxh like 'X%' and mapnxh = '" & Trim(txtmapnx) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Neu chua ton tai, chac chan chua co
rs.AddNew
rs!mapnxh = Trim(txtmapnx)
rs!ngaylappnx = Trim(txtngaylappnx)
rs!maddh = Trim(Left(Combomaddh.Text, 5))
rs!makho = Trim(Left(Combomakho.Text, 5))
rs!ngaynxh = Trim(txtngaynx)
rs!ngayhtt = Trim(txtngayhtt)
rs.Update
Set rs = Nothing ' Dong record lai
End If
Set cmd.ActiveConnection = con
str = "Select DONGNXHANG.mapnxh, DONGNXHANG.mahang, DONGNXHANG.soluongnxh, DONGNXHANG.dongianxh from DONGNXHANG where mapnxh like 'X%' and mapnxh = '" & Trim(txtmapnx) & "' and mahang = '" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Neu chua ton tai
rs.AddNew
rs!mapnxh = Trim(txtmapnx)
rs!mahang = Trim(Left(Combomahang.Text, 4))
rs!soluongnxh = Trim(txtsoluongnx)
rs!dongianxh = Trim(txtdongianx)
rs.Update
Set rs = Nothing
End If
'Chi tiet mat hang phai duoc tao moi sau cung
Set cmd.ActiveConnection = con
str = "select CTMATHANG.mahang, CTMATHANG.soluongton from CTMATHANG where CTMATHANG.mahang ='" & Trim(Left(Combomahang.Text, 4)) & "'"
rs.Open str, con, adOpenKeyset, adLockPessimistic, adCmdText
If rs.EOF = True Then 'Chac chan chua co
rs.AddNew
rs!mahang = Trim(Left(Combomahang.Text, 4))
rs!soluongton = sltontam
rs.Update
Set rs = Nothing
sltontam = 0 'Xoa gia tri
End If
End If
End If
toithieu = 0 'Xao gia tri
toida = 0 'Xao gia tri
Else 'Neu da ton tai phieu xuat hang nay roi
MsgBox "Phieu xuat hang co ma so [" & Trim(txtmapnx) & "] da ton tai. Vui long kiem tra lai !", vbOKOnly + vbExclamation, "Thong bao"
txtmapnx.SetFocus
Me.MousePointer = 0
Exit Sub
End If
DisplayGrid 'Hien thi danh sach cac hang san xuat
error1:
If Err.Number 0 Then
MsgBox Err.Number & Err.Description
Else
MsgBox "Luu thanh cong phieu xuat hang co ma so: '" & Trim(txtmapnx) & "'"
response = MsgBox("Ban co muon them mat hang vao phieu xuat hang nua khong ?", vbYesNo + vbQuestion, "Thong bao")
If response = vbYes Then 'Neu chon NO thi khong Xoa
Locktext
Unlocktext2
Setnull2 'Xoa Textbox
Combomahang.SetFocus
Flag = True
Else
Setnull2 'Xoa Textbox
Locktext
End If
End If
End Sub
CHÖÔNG V
ÑAÙNH GIAÙ HEÄ THOÁNG
I. Nhöõng keát quaû ñaït ñöôïc
Heä thoáng quaûn lyù xuaát nhaäp haøng giuùp cho vieäc quaûn lyù mua baùn cuûa coâng ty ñöôïc thöïc hieän moät caùch thuaän tieän nhanh choùng vaø an toaøn, goùp phaàn tieát kieäm thôøi gian vaø giaûm bôùt caùc coâng vieäc thuû coâng (tuy nhieân khoâng theå thay theá hoaøn toaøn).
Heä thoáng ñaùp öùng ñöôïc nhöõng yeâu caàu cô baûn trong coâng taùc caäp nhaät, xöû lyù xuaát nhaäp haøng moät caùch nhanh choùng, chính xaùc nhö caäp nhaät döõ lieäu, tìm kieám thoâng tin, baùo caùo toång hôïp xuaát, nhaäp, toàn haøng.
Giao dieän thaân thieän vaø deã daøng cho ngöôøi söû duïng.
II. Nhöõng toàn taïi cuûa chöông trình
Trong ñieàu kieän haïn heïp veà thôøi gian vaø kieán thöùc coøn haïn cheá neân chöông trình vaãn coøn moät soá toàn taïi nhö sau:
Heä thoáng chæ môùi phaùt trieån baèng ngoân ngöõ VisualBasic, löu tröõ döõ lieäu baèng heä quaûn trò côû sôû döõ lieäu MicroSoft SQL Server vaø chaïy treân maùy ñôn.
Moät soá phaàn xöû lyù Tieáng Vieät coøn chö toát.
Chöa xaây döïng heä thoáng baûo maät cô sôû döõ lieäu vaø phaân quyeàn ngöôøi söû duïng.
III. Höôùng phaùt trieån chöông trình
Döïa vaøo keát quaû khaûo saùt baøi toaùn thöïc teá vaø phaân tích thieát keá heä thoáng ôû treân, em xin ñeà xuaát höôùng phaùt trieån chöông trình nhö sau:
1. Phaùt trieån heä thoáng
Xaây döïng heä thoáng thöông maïi ñieän töû Web baèng coâng ngheä ASP (Active Server Pages) hoaëc ASP.Net, löu tröõ döõ lieäu baèng heä quaûn trò cô sôû döõ lieäu MicroSoft SQL Server hoaëc Orecle vaø chaïy treân maïng.
2. Baûo maät cô sôû döõ lieäu vaø phaân quyeàn ngöôøi söû duïng
Ta seõ phaân caáp ra 3 möùc ngöôøi söû duïng:
Addmin: coù quyeàn theâm, söûa, xoaù database, phaân caáp, phaân quyeàn cho ngöôøi söû duïng.
User möùc 1: coù quyeàn theâm döõ lieäu vaø database.
User möùc 2: chæ ñöôïc quyeàn xem maø khoâng ñöôïc thöïc hieän baát cöù thao taùc gì treân database.
Moät vaán ñeà nöõa laø database seõ ñöôïc ñaët treân maùy chuû chöù khoâng ñaët treân caùc maùy con nhö hieän nay nöõa vaø nhö vaäy vieäc quaûn trò vaø baûo maät ddatabase seõ deã daøng hôn.
TAØI LIEÄU THAM KHAÛO
1. Microsoft Visual Basic 6.0 & Laäp trình cô sôû döõ lieäu
– Nguyeãn Thò Ngoïc Mai (Chuû bieân), NXB GIAÙO DUÏC
Laäp trình Visual Basic trong 21 ngaøy – Nathan Gurewich – On Gurewich, NXB GIAÙO DUÏC.
Keá toaùn doanh nghieäp vôùi Visual Basic – VN GUIDE, NXB Thoáng Keâ.
Giaùo trình phaân tích vaø thieát keá heä thoáng thoâng tin quaûn lyù – ThS.Nguyeãn Höõu Troïng, Tröôøng Ñaï Hoïc Thuyû Saûn.
Phaân tích vaø thieát keá heä thoáng thoâng tin - Nguyeãn Vaên Ba, NXB ÑAÏI HOÏC QUOÁC GIA HAØ NOÄI.
Höôùng daãn trieån khai Caên Cöù Döõ Lieäu söû duïng SQL SERVER 7.0 vaø VISUAL BASIC 6.0 - Bieân dòch: Döông Quang Thieän, NXB Thoáng Keâ.