Lời Nói Đầu
Chất lượng học tập của Học Sinh / Sinh Viên luôn là một vấn đề mà Bộ Giáo Dục rất quan tâm . Để nâng cao chất lượng học tập Bộ Giáo Dục đã đưa ra rất nhiều biện pháp , từ nâng cao chất lượng dạy của giáo viên , học của Học Sinh / Sinh Viên đến việc cải cách chương trình dạy và rất nhiều biện pháp khác nhưng có lẽ thi trắc nghiệm là một trong những biện pháp có hiệu quả nhất vì nó là một lối thi đòi hỏi phải có một lượng kiến thức đầy đủ cùng với sự thông minh và nhanh nhẹn của từng học sinh / sinh viên .
Vì những yêu cầu trên và cùng với một công nghệ hết sức mới hiện nay trong lĩnh vực công nghệ thông tin là bộ .NET của Microsoft và SQL Server 2000 mà chúng em đã xây dựng nên chương trình Thi Trắc Nghiệm này với các chức năng :
+ Quản trị dữ liệu đề thi .
+ Thực hiện chức năng thi trắc nghiệm trên máy cho người dùng
Mục đích của chương trình là:
+ Hổ trợ cho Giáo Viên thuận lợi trong việc soạn câu hỏi trắc nghiệm , soạn đề thi trắc nghiệm .
+ Cho phép Giáo Vụ soạn đề thi trắc nghiệm , soạn bộ đề ra thi .
+ Tạo điều kiện dễ dàng và nhanh chóng cho Sinh Viên thi trắc nghiệm được chính xác và công bằng .
Sau khi hoàn thành đề tài này chúng em mong được góp một phần công sức của mình vào sự nghiệp đổi mới ngày một tiến bộ của Bộ Giáo Dục nói riêng và xã hội nói chung , mặc dù chương trình của chúng em vẩn còn không ít thiếu sót kính mong quý Thầy, Cô tận tình chỉ bảo để chúng em có thể rút ra được nhiều kinh nghiệm quý báu cho bản thân .
Mục Lục
PHẦN I. TÌM HIỂU NGÔN NGỮ 1
CHƯƠNG 1 : TÌM HIỂU NGÔN NGỮ VISUAL BASIC.NET 1
I. Tổng quan về VisualBasic.NET . 1
1. Giới thiệu Visual Basic.NET . 1
2. Những nét mới trong Visual Basic.NET . 2
3. Làm việc với các bộ xử lý lỗi . 7
4. Làm việc với Crystal Report . 13
5. Trình duyệt Internet . 15
6. Tạo ứng dụng Web . 16
7. Web Service . 18
8. Xây dựng Help Online . 19
II. Tìm hiểu cơ cấu .NET . 20
1. Tham khảo sơ lược về .NET Framework . 20
2. Tìm hiểu CLR 20
3. Siêu dữ kiện Metadata . 21
4. Quá trình thực thi của CLR 22
5. Lập trình trong môi trường .NET 23
6. Làm việc với các công cụ .NET . 25
III. Kiểu dữ liệu . 25
1. Đối tượng và tập hợp 25
2. Array . 27
3. Các kiểu dữ liệu thường dùng . 27
4. Sử dụng các chuổi 27
5. Kiểu dữ liệu Double 28
6. Làm việc với Date . 28
7. Sử dụng các giá trị Boolean . 28
8. Tạo Structure 29
9. Làm việc với Enumeration . 29
IV. Thủ tục , hàm và biểu thức logic . 30
1. Tìm hiểu về biến . 30
2. Chuyển thông tin . 30
3. Cách xây dựng logic cho chương trình 32
V. Ứng Dụng cơ sở dữ liệu . 34
1. Thế nào là cơ sở dữ liệu . 34
2. Thiết cơ sở dữ liệu 34
3. Trình bày cấu trúc cơ sở dữ liệu . 35
VI. Truy cập CSDL 35
1. ADO so với ADO.NET 35
2. Đối tượng ADO 36
3. Giới thiệu ADO.NET . 37
CHƯƠNG 2 : TÌM HIỂU NGÔN NGỮ SQL SERVER 2000 41
I. SQL Server là gì ? . 41
II. Tạo một Database 41
1. Tạo Database 41
2. Đổi tên Database 42
3. Hủy Database 43
III. Table 43
1. Các loại dữ liệu . 43
2. Tạo một bảng . 44
3. Sửa cấu trúc bảng . 45
4. Xóa một bảng 45
5. Thuộc tính Identity 45
6. Sử dụng kiểu dữ liệu Uniqueidentifier và hàm Newid 46
7. Nhập một mẩu tin mới vào table . 46
8. Xóa dữ liệu . 46
IV. Ràng buộc toàn vẹn . 46
1. Các loại ràng buột toàn vẹn . 46
2. Xóa một ràng buột . 47
3. Giá trị mặc nhiên 47
4. Check constrait . 47
5. Primary Key . 48
6. Unique 48
7. Foreign Key 48
V. Truy vấn dữ liệu bằng phát biểu SELECT 49
1. Câu lệnh Select . 49
2. Biến đổi dữ liệu 50
3. Chuyển đổi dữ liệu 52
4. Tương quan dữ liệu 52
5. Làm việc với các truy vấn con . 53
6. Phát biểu Select Into . 54
7. Toán tử Union 54
VI. Hiệu chỉnh dữ liệu . 54
1. Chèn dữ liệu . 54
2. Xóa dữ liệu 54
3. Cập nhật dữ liệu 54
VII. Sử dụng các phần mở rộng của Transact-SQL 55
1. Sript . 55
2. Các thành phần của ngôn ngữ Control-of-flow 55
VIII. Tạo chỉ mục 56
IX. Tạo View, trigger, store procedurevà function . 56
1. Tạo và thao tác trên View 56
2. Làm việc với các thủ tục lưu trữ hệ thống 56
3. Làm việc với Trigger . 57
4. Làm việc với các hàm do người dùng định nghĩa 57
PHẦN II. PHÂN TÍCH THIẾT KẾ VÀ CÀI ĐẶT CHƯƠNG TRÌNH
I. Phân tích chương trình 59
1. Đặt tả sơ lược hệ thống xây dựng chương trình Thi Trắc Nghiệm . 59
2. Phân tích hệ thống Thi Trắc Nghiệm bằng Rational Rose . 60
3. Chọn mô hình cài đặt về cơ sở dữ liệu 77
II. Thiết kế chương trình . 77
1. Mô tả các table . 77
2. Ràng buột toàn vẹn 78
3. Sơ đồ quan hệ ERD 83
III. Cài đặt chương trình 93
PHẦN III. TỔNG KẾT
I. Nhận xét chung 99
1. Đánh giá kết quả của chương trình . 99
2. Hạn chế của chương trình 99
II. Hướng phát triển chương trình 99
III. Kết luận . 100
Tài liệu tham khảo . 101
102 trang |
Chia sẻ: lvcdongnoi | Lượt xem: 2543 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Luận văn Xây dựng chương trình thi trắc nghiệm bằng vb.net, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
u soá nguyeân (int , smallint , tinyint) hoaëc kieåu number , decimal (phaûi khai baùo scale=0 ).
+ Coù theå khai theâm tham soá IDENT_SEED (giaù trò baét ñaàu) vaø IDENT_INCR (giaù trò taêng theâm) .
+ Haøm @@IDENTUTY cho bieát giaù trò identity cuoái cuøng ñaõ söû duïng ñeå ñöa giaù trò vaøo 1 haøng trong phieân laøm vieäc (session) .
+ Coù theå söû duïng töø khoaù IDENTITYCOL thay theá teân coät khi truy vaán döõ lieäu
Cuù phaùp
CREATE TABLE(
IDENTITY [(seed, increment)] {NOT NULL], [ ,...})
Söû duïng kieåu döõ lieäu UNIQUEIDENTIFIER vaø HAØM NEWID
Kieåu uniqueidentifier vaø haøm NEWID ñöôïc duøng chung vôùi nhau . Ñaëc ñieåm :
+ Kieåu uniquedentifier löu moät soá 16 bytes (128 bit) duy nhaát (unique). Kieåu naøy duøng ñeå löu giaù trò naøy duy nhaát toaøn cuïc (GUID – Globaly Unique Identifier) .
+ Haøm NEWID taïo moät GUID coù theå duøng ñeå löu giaù trò vaøo kieåu uniqueidentifier . Giaù trò GUID seõ khoâng gioáng nhau trong taát caû caùc table cuûa moät database, keå caû trong database khaùc . Thöôøng duøng trong vieäc nhaân baûn , khi caàn ñeán moät maø nhaän dieän treân caû caùc heä thoáng.
Nhaäp moät maåu tin môùi vaøo table :
Cuù phaùp :
INSERT [INTO] table_name VALUES (val1 , val2 , … , valn)
Hoaëc :
INSERT [INTO] table_name (column_list) VALUES (val1 , val2 , … , valn)
Xoùa döõ lieäu :
Cuù phaùp :
TRUNCATE TABLE table_name
Hoaëc :
DELETE table_name
WHERE condition
Xoùa döõ lieäu beân trong table
RAØNG BUOÄT TOAØN VEÏN :
Caùc loaïi raøng buoäc toaøn veïn döõ lieäu (DATA INTERGRITY)
Coù theå chia laøm 4 loaïi toaøn veïn döõ lieäu :
+ Toaøn veïn veà mieàn giaù trò (domain integrity)
+ Toaøn veïn ñoái vôùi thöïc theå (entity integrity)
+ Toaøn veïn tham chieáu ( referential integrity)
+ Toaøn veïn do ngöôøi söû duïng ñònh nghóa .
Loaïi toaøn veïn
Raøng buoät
Domain
DEFAULT
CHECK
FOREIGN KEY
Check
PRIMARY KEY
UNIQUE
Referential
FOREIGN KEY
User-defined
CHECK
Ta coù theå khai baùo raøng buoäc khi taïo baûng ( CREATE TABLE), hoaëc boå sung ñieàu chænh sau khi ñaõ taïo xong (ALTER TABLE)
Ñeå lieät keâ caùc raøng buoäc ñaõ caøi ñaët cho moät table, ta duøng
EXEC sp_helpconstraint
Xoaù moät raøng buoäc :
ALTER TABLE
DROP CONSTRAINT
Giaù trò maëc nhieân (DEFAULT) :
Caùch 1 :
CREATE TABLE
( DEFAULT , [ , ... ])
Caùch 2 :
CREATE TABLE (
COSNTRAINT DEFAULT , [, ... ])
Caùch 3 :
ALTER TABLE
ADD CONSTRAINT
DEFAULT FOR
CHECK constraint
CHECK cho pheùp kieåm tra giaù trò trong moät hoaëc nhieàu coät trong table. Döõ lieäu phaûi thoûa maõn bieåu thöùc logic trong raøng buoäc CHECK thì môùi ñöôïc chaáp nhaän
Caùch 1 :
CREATE TABLE(
CHECK [ , ... ],
CONSTRAINT CHECK )
Caùch 2 :
CREATE TABLE (
CONSTRAINT CHECK [ , … ])
Caùch 3 :
ALTER TABLE
ADD CONSTRAINT CHECK
PRIMARY KEY:
Caùch 1 :
CREATE TABLE
( PRIMARY KEY [ , … ], )
Caùch 2 :
CREATE TABLE ( [ , … ],
CONSTRAINTPRIMARY KEY(,, … )
Caùch 3 :
ALTER TABLE
ADD CONSTRAINTPRIMARYKEY(,,…)
UNIQUE:
Caùch 1 :
CREATE TABLE (UNIQUE[,....], )
Caùch 2 :
CREATE TABLE (
CONSTRAINT UNIQUE, [,......] )
Caùch 3 :
CREATE TABLE ( [,.........],
CONSTRAINT UNIQUE (,,.....))
Caùch 4 :
ALTER TABLE
ADD CONSTRAINTUNIQUE,,...)
FOREIGN KEY:
Caùch 1 :
CREATE TABLE
( REFERENCES ) [,...], )
Caùch 2:
CREATE TABLE ( ,
CONSTRAINTREFERENCES()[,...])
Caùch 3 :
CREATE TABLE([,...] , CONSTRAINT REFERENCES ([,.. ] ))
Caùch 4 :
ALTER TABLE
ADD CONSTRAINTREFERENCES(, [,..])
TRUY VAÁN DÖÕ LIEÄU BAÈNG PHAÙT BIEÅU SELECT :
Caâu leänh SELECT :
Caâu leänh SELECT treân moät Table:
Cuù phaùp :
SELECT [ DISTINCT] [TOP n]
FROM
WHERE
GROUP BY
HAVING
ORDER BY
Chuù yù :
( % ) : Ñaïi dieän cho nhieàu kyù töï
( _ ) : Ñaïi dieän cho moät kyù töï
Caâu leänh SELECT treân nhieàu table:
Hai table:
Caùch 1:
SELECT
FROM T1,T2
WHERE
Caùch 2 :
SELECT
FROM T1 [INNER] JOIN T2
ON
Chuù yù: Coù theå boû chöõ INNER treân FROM
Keát nhieàu hôn hai table:
Caùch 1:
SELECT
FROM T1 , T2 , .......... , Tn
WHERE
Caùch 2:
SELECT
FROM T1 [INNER] JOIN T2
ON[INNER] JOIN T3
ON. . .
Chuù yù:
n table coù ít nhaát (n-1) ñieàu kieän lieân keát .
Thay ñoåi tieâu ñeà coät :
Cuù phaùp :
SELECT column_heading = column_name
FROM table_name
Bieán ñoåi döõ lieäu :
Caùc toaùn töû soá hoïc :
Kieåu döõ lieäu
Pheùp toaùn +
Pheùp toaùn -
Pheùp toaùn chia (/)
Pheùp toaùn nhaân (*)
Pheùp toaùn Module (%)
Bigint
Yes
Yes
Yes
Yes
Yes
Decimal
Yes
Yes
Yes
Yes
No
Float
Yes
Yes
Yes
Yes
No
Int
Yes
Yes
Yes
Yes
Yes
Money
Yes
Yes
Yes
Yes
No
Numeric
Yes
Yes
Yes
Yes
No
Real
Yes
Yes
Yes
Yes
No
Smallint
Yes
Yes
Yes
Yes
Yes
Smallmoney
Yes
Yes
Yes
Yes
No
Tinyint
Yes
Yes
Yes
Yes
Yes
Caùc haøm toaùn hoïc thöôøng duøng :
Caùc haøm toaùn hoïc cho pheùp baïn thöïc hieän caùc pheùp toaùn caàn thieát thoâng thöôøng treân döõ lieäu toaùn hoïc . Baïn coù theå traû veà döõ lieäu toaùn hoïc baèng caùch söû duïng cuù phaùp sau :
Cuù phaùp :
SELECT function_name(parameters)
Haøm
Keát quaû
ABS (numeric_expr)
Giaù trò tuyeät ñoái.
COS | SIN | COT | TAN(float_expr)
Laø soá cos , sin hoaëc tan cuûa goùc (theo radian).
EXP(float_expr)
Giaù trò muõ cuûa giaù trò xaùc ñònh .
LOG(float_expr)
Soá log töï nhieân .
LOG10(float_expr)
Log cô soá 10 .
PI( )
Haèng soá 3.141592653589793.
POWER(numeric_expr , y )
Giaù trò cuûa numeric_expr luõy thöøa y .
ROUND(numeric_expr , len )
Soá numeric_expr laøm troøn ñeán chieàu daøi xaùc ñònh trong moät soá nguyeân
SQUARE(float_expr)
Bình phöông giaù trò xaùc ñònh .
SQRT(float_expr)
Caên cuûa giaù trò xaùc ñònh .
Caùc haøm chuoãi thöôøng duøng:
Baïn coù theå traû veà döõ lieäu kyù töï baèng caùch söû duïng cuù phaùp sau :
Cuù phaùp : SELECT function_name(parameters)
Haøm
Keát quaû
‘expr’+’ expr’
Keát noái hai hay nhieàu chuoãi kyù töï .
ASSCII(char_ expr)
Traû veà giaù trò maõ ASSCII cuûa kyù töï saùt beân traùi .
CHAR(integer_ expr)
Traû veà kyù töï töông öùng vôùi giaù trò maõ ASSCII
LEFT(char_ expr1,integer_ expr)
Traû veà moät chuoãi kyù töï baét ñaàu töø beân traùi vaø ñöùng tröôùc integer_ expr kyù töï .
LOWER(char_ expr)
Chuyeån thaønh chöõ thöôøng .
LTRIM(char_ expr)
Traû veà döõ lieäu khoâng coù khoaûng traéng ñaèng tröôùc .
REPLACE(‘string1’,’string2’,’string3’)
Thay theá taát caû laàn xuaát hieän string2 trong string1 baèng string3
RIGHT(char_ expr,integer_ expr)
Traû veà moät chuoåi kyù töï baét ñaàu töø integer_expr kyù töï tính töø beân phaûi .
RTRIM(char_ expr)
Traû veà döõ lieäu khoâng coù khoaûng traéng ôû ñaèng sau .
SPACE(integer_ expr)
Traû veà moät chuoãi laäp laïi integer_expr khoaûng traéng .
SUBSTRING(expr , stary,length )
Traû veà moät phaàn chuoåi kyù töï hoaëc chuoãi nhò phaân .
UNICODE(‘nchar_string’)
Traû veà giaù trò soá theo maõ Unicode cuûa kyù töï ñaàu tieân trong ‘nchar_expr’
UPPER(char_ expr)
Chuyeån thaønh chöõ hoa .
Caùc haøm ngaøy thaùng :
Baïn coù theå bieán ñoåi caùc giaù trò thuoäc kieåu datetime baèng caùch söû duïng caùc haøm ngaøy thaùng . Baïn coù theå söû duïng caùc haøm ngaøy thaùng trong column_list , meänh ñeà WHERE hoaëc baát kyø bieåu thöùc naøo coù theå ñöôïc söû duïng . Ñeå laøm ñöôïc nhö vaäy , söû duïng cuù phaùp sau :
Cuù phaùp : SELECT date_name(parameters)
Haøm
Keát quaû
DATEADD(datepart,number, date)
Theâm soá datepart vaøo date.
DATEDIFF(datepart, date1, date2)
Traû veà soá datepart giöõ hai ngaøy .
DATENAME(datepart, date)
Traû veà giaù trò ASCII cho giaù trò datepart cuûa ngaøy date.
DATEPART(datepart, date)
Traû veà giaù trò integer cho giaù trò cuûa datepart cuûa ngaøy date .
DATE(date)
Traû veà moät giaù trò soá nguyeân theå hieän ngaøy .
GETDATE()
Traû veà ngaøy giôø hieän haønh .
MONTH(date)
Traû veà moät giaù trò soá nguyeân theå hieän thaùng .
YEAR(date)
Traû veà moät giaù trò soá nguyeân theå hieän naêm
Chuyeån ñoåi döõ lieäu :
Bôûi vì nhieàu haøm yeâu caàu döõ lieäu theo moät daïng hoaëc kieåu döõ lieäu naøo ñoù , baïn coù theå caàn chuyeån ñoåi töø moät kieåu döõ lieäu naøy sang kieåu döõ lieäu khaùc . Baïn söû duïng haøm CONVER( ) hoaëc CAST( ) ñeå hieäu chænh caùc kieåu döõ lieäu cuûa baïn. Baïn coù theå söû duïng haøm CONVERT( ) ôû baát kyø nôi naøo bieåu thöùc cho pheùp ; noù coù cuù phaùp nhö sau :
Cuù phaùp : CONVERT (datatype [(length)], expr [,style])
Töông quan döõ lieäu :
Keát noái trong (Inner join):
Caùc Inner Join taïo ra caùc thoâng tin khi thoâng tin so saùnh tìm thaáy trong caû hai baûng . Loaïi thoâng thöôøng nhaát cuûa keát noái Inner Join laø
+ Equijoin caùc giaù trò coät ñöôïc so saùnh baèng nhau vaø caùc coät thöøa ñöôïc theå hieän laø caùc coät trong taäp keát .
+ Natural join caùc coät thöøa khoâng ñöôïc theå hieän hai laàn . Trong moät Natural join , caùc giaù trò coät ñöôïc so saùnh baèng nhau nhöng caùc coät dö thöøa bò giôùi haïn töø caùc coät trong taäp keát quaû .
OUTER JOIN :
Baïn coù theå trích xuaát caùc doøng töø moät baûng trong khi cho cheùp taát caû caùc doøng töø caùc baûng khaùc thaønh taäp keát quaû cuûa baïn baèng caùch söû duïng outer join . Caùc toaùn töû cuûa outer join vaø caùc töø khoùa cuûa cuù phaùp ANSI nhö sau :
+ LEFT OUTER JOINT : Bao goàm taát caû caùc doøng töø baûng thöù nhaát vaø chæ caùc doøng so khôùp trong baûng thöù hai .
+ RIGHT OUTER JOIN : Bao goàm taát caû caùc doøng töø baûng thöù hai vaø chæ caùc doøng so khôùp trong baûng thöù nhaát.
+ FULL OUTER JOIN : Bao goàm taát caû caùc doøng töø hai baûng cuõng nhö caùc doøng so khôùp .
CROS hay UNRESTRICTED SELF JOIN :
Caùc keát noái cheùo hoaëc khoâng giôùi haïn traû veà moät söï keát hôïp cuûa taát caû caùc doøng cuûa taát caû caùc baûng trong keát noái thaønh taäp keát quaû .
Töï keát noái :
Moät Self join lieân keát caùc doøng cuûa moät baûng vôùi caùc doøng khaùc trong cuøng moät baûng Caùc truy vaán so saùnh ñoái vôùi cuøng thoâng tin ñöôïc söû duïng haàu heát caùc keát noái töï keát (Self join).
Laøm vieäc vôùi caùc truy vaán con (Subquery) :
Moät pheùp keát noái coù theå ñöôïc söû duïng thay cho truy vaán con ; Tuy nhieân , moät soá tröôøng hôïp ñaëc bieät chæ coù theå thöïc hieän caâu truy vaán con . Moät truy vaán con coù theå chöùa caùc truy vaán con khaùc vaø truy vaán con ñoù coù theå chöùa moät truy vaán con khaùc … Trong thöïc teá khoâng coù gì giôùi haïn soá löôïng caùc truy vaán con coù theå ñöôïc thöïc hieän tröø caùc taøi nguyeân cuûa heä thoáng .
Cuù phaùp :
(SELECT [ ALL | DISTINCT ] subquery_column_list
[FROM table_list]
[WHERE clause]
[GROUP BY clause]
[HAVING clause])
Baïn coù theå taïo vaø söû duïng moät truy vaán con theo caùc quy taéc sau :
+ Noù phaûi ñöôïc ñaët trong caùc daáu ngoaëc ñôn .
+ Neáu söû duïng khi moät bieåu thöùc giaù trò ñôn ñöôïc söû duïng , noù phaûi traû veà moät giaù trò ñôn .
+ Noù khoâng theå ñöôïc söû duïng trong meänh ñeà ORDER BY .
+ Noù khoâng theå chöùa moät meänh ñeà ORDER BY , COMPUTE hoaëc SELECT INTO.
+ Noù khoâng theå coù nhieàu hôn moät coät trong column_list neáu söû duïng trong meänh ñeà IN .
+ Noù phaûi coù SELECT * neáu söû duïng vôùi meänh ñeà EXISTS.
+ Caùc kieåu döõ lieäu Text vaø Image khoâng cho pheùp coù trong danh saùch choïn (field) (ngoaïi tröø ñoái vôùi vieäc söû duïng *)
+ Noù khoâng theå bao goàm caùc meänh ñeà GROUP BY vaø HAVING neáu söû duïng vôùi moät pheùp toaùn so saùnh khoâng bieán ñoåi (moät truy vaán khoâng coù baát kyø töø khoùa ANY hoaëc ALL).
Phaùt bieåu Select Into :
Phaùt bieåu Select Into cho pheùp baïn taïo moät baûng môùi döïa treân caùc keát quaû truy vaán .
Cuù phaùp :
SELECT column_list
INTO new_table_name
FROM table_name
WHERE search_criteria
Toaùn töû Union :
Baïn coù theå keát noái caùc keát quaû cuûa hai hay nhieàu truy vaán thaønh moät taäp keát quaû ñôn baèng caùch söû duïng toaùn töû UNION
HIEÄU CHÆNH DÖÕ LIEÄU :
Cheøn döõ lieäu :
Phaùt bieåu INSERT cô baûn ôû moät thôøi ñieåm theâm moät doøng vaøo trong moät baûng.
Cuù phaùp :
INSERT [ INTO ] { table_or_view }{{ [(column_list)]
VALUES
({DEFAULT | constant_expr}[,…n]) | select_statement} | DEFAULT VALUES}
Table_or_view ::= { table_name | view_name | rowset_function} [, … n]
Xoùa döõ lieäu :
Khi baïn söû duïng caâu leänh DELETE , baïn coù theå gôõ boû moät hoaëc nhieàu doøng töø moät baûng .
Cuù phaùp :
DELETE [FROM]{table_name | view_name}
[WHERE clause]
Caäp nhaät döõ lieäu :
Phaùt bieåu UPDATE cho pheùp baïn thay ñoåi caùc giaù trò cuûa coät trong phaïm vi caùc doøng coù saún .
Cuù phaùp :
UPDATE
{table_name | view_name}
SET
Column_name1 ={expr | NULL | select_statement )}[, col_name2 = … ]
[ WHERE search_conditions ]
SÖÛ DUÏNG CAÙC PHAÀN MÔÛ ROÄNG CUÛA TRANSACT-SQL :
Sript :
Sau khi taïo caùc ñoái töôïng nhö table, view,... trong 1 database. Ta coù theå söû duïng SQL Server Enterprise Manager ñeå laäp söu lieäu cho database baèng caùch taïo ra moät hoaëc nhieàu Transact-SQL script. nhöõng script naøy seõ chöùa caùc caâu leänh ñeå ta coù theå deã daøng taïo laïi database vaø caùc ñoái töôïng beân trong noù.
caùc böôùc ñeå sinh script
+ Môû SQL Server Enterprise Manager
+ Choïn database muoán sinh script. baám nuùt phaûi chuoät treân database naøy, choïn All Task -> Generate SQL Scripts...
+ Treân tab Generate, maëc nhieân taát caû caùc ñoái töôïng ñeàu ñöôïc ñöa vaøo script, ta choïn löïa laïi caùc ñoái töôïng caàn ñöa vaøo scripts.
+ Coù theå nuùt Preview... ñeå xem tröôùc keát quaû sinh ra.
Choïn OK -> ñaët laïi teân cho file löu laïi (maëc nhieân phaàn môû roäng .sql)
Caùc thaønh phaàn cuûa ngoân ngöõ Control-of-flow :
Khoái IF … ELSE :
Khoái If … else cho pheùp moät phaùt bieåu ñöôïc thöïc thi tuøy theo ñieàu kieän .
Cuù phaùp :
IF Boolean_expr
{sql_statement | statement_block}
ELSE[Boolean_expr]
{ sql_statement | statement_block}
Bieåu thöùc CASE :
Bieåu thöùc CASE cho pheùp caùc bieåu thöùc T-SQL , ñöôïc ñôn giaûn so vôùi giaù trò ñieàu kieän
Cuù phaùp :
CASE expr
WHEN expr1 THEN expr1
[[WHEN expr2 THEN expr2 ] […]]
ELSE exprN
END
TAÏO CHÆ MUÏC :
taïi sao phaûi duøng chæ muïc :
Coù hai lyù do chính ñeå söû duïng chæ muïc laø :
+ Toác ñoä .
+ Chæ muïc taïo tính duy nhaát .
Taïo chæ muïc :
CREATE[UNIQUE][CLUSTERED | NONCLUSTERED]INDEX Index_Name
ON Table ( column] [, …])
Xoùa chæ muïc :
DROP INDEX table.Index_Name [, …]
TAÏO VIEW , TRIGGER , STORE PROCEDURE VAØ FUNCTION
Taïo vaø thao taùc treân View :
View laø phöông tieän cho pheùp ta löu moät caâu truy vaán thaønh moät ñoái töôïng trong CSDL . Sau khi taïo xong ta coù theå laøm vieäc vôùi view töông töï nhö vôùi Table. Tuy nhieân view chæ laø moät khung nhìn, döõ lieäu thöïc söï chæ chöùa trong table maø thoâi. Caùc View (baûng nhìn ) cho pheùp baïn chia ngang hoaëc chia doïc thoâng tin töø moät hoaëc nhieàu baûng trong moät CSDL .
Taïo View :
Cuù phaùp :
CREATE VIEW View_name [(colunm1] [,…])]
AS Select statement
Xoùa View :
DROP VIEW View_Name [, …]
Ñieàu chænhView :
ALTER VIEW View_name [(column] [, …])]
AS Select_statement
Laøm vieäc vôùi caùc thuû tuïc löu tröõ heä thoáng :
Caùc thuû tuïc löu tröõ heä thoáng laø caùc taäp leänh T-SQL chaïy nhanh ñöôïc löu tröõ trong moät CSDL cuûa SQL Server . Caùc thuû tuïc löu tröõ heä thoáng coù raát nhieàu lôïi ích nhö :
+ Sau khi noù thöïc hieän , löôïc ñoà cuûa thuû tuïc ñöôïc löu tröõ trong vuøng ñeäm coù thuû tuïc .
+ Baïn coù theå söû duïng thuû tuïc löu tröõ heä thoáng ñeå ñoùng goùi caùc quy taéc nghieäp vuï + Hieäu quaû thöïc hieän ñöôïc naâng leân cho taát caû caùc thuû tuïc löu tröõ heä thoáng vaø thaäm chí nhieàu hôn so vôùi caùc thuû tuïc löu tröõ heä thoáng ñöôïc chaïy nhieàu hôn moät laàn laø do keá hoaïch truy vaán ñöôïc löu trong vuøng ñeäm thuû tuïc .
+ Vôùi caùc thuû tuïc löu tröõ heä thoáng , baïn coù theå truyeàn ñoái soá vaøo vaø nhaän döõ lieäu traû veà .
+ Caùc thuû tuïc löu tröõ heä thoáng coù theå ñöôïc thieát laäp ñeå chaïy töï ñoäng .
+ Caùc thuû tuïc löu tröõ heä thoáng coù theå ñöôïc söû duïng ñeå trích xuaát hoaëc hieäu chænh döõ lieäu .
+ Caùc thuû tuïc löu tröõ heä thoáng ñöôïc goïi moät caùch roõ raøng . Khoâng gioáng nhö trigger , caùc thuû tuïc löu tröõ heä thoáng phaûi ñöôïc goïi bôûi öùng duïng , script , batch , taùc vuï cuûa baïn .
Cuù phaùp :
CREATE PROC[ EDURE ] procedore_name {;number}
[{@parameter data_type} [ VARYING] [ = default] [ OUTPUT ]] [, …n ]
[WITH { RECOMPILE | ENCRYTION | RECOMPILE ,ENCRYPTION} ]
[ FOR REPLICATION] AS sql_statement [… n]
Laøm vieäc vôùi Trigger :
Trigger laø moät loaïi thuû tuïc löu tröõ ñaëc bieät töï ñoäng thöïc hieän khi baïn coá hieäu chænh döõ lieäu maø ñöôïc thieát keá laø ñöôïc baûo veä . Caùc Trigger baûo ñaûm toaøn veïn döõ lieäu baèng caùch baûo veä caùc söï thay ñoåi khoâng nhaát quaùn vaø khoâng ñöôïc pheùp .
Baïn coù theå söû duïng caùc trigger ñeå thöïc hieän caùc quy taéc nghieäp vuï phöùc taïp hôn laø baïn coù theå laøm vôùi caùc raøng buoäc .Caùc trigger khoâng coù thoâng soá vaø khoâng theå ñöôïc thöïc thi roõ raøng . Baïn coù theå loàng caùc trigger tôùi 32 caáp .
Veà maëc hieäu quaû , caùc trigger coù toång phí töông ñoái thaáp vì haàu heát thôøi gian thöïc hieän cuûa trigger laø ñöôïc söû duïng cho vieäc tham chieáu caùc baûng khaùc .
Cuù phaùp :
CREATE TRIGGER [ower.] trigger_name
ON [ower.] table_name | view_name
[ FOR . . ALTER | INSTEAD OF | INSERT | UPDATE | DELETE
[ WITH ENCRYPTION] AS sql_statement
Laøm vieäc vôùi caùc haøm do ngöôøi duøng ñònh nghóa :
Moät tính naêng maïnh cuûa SQL Server 2000 laø haøm do ngöôøi duøng ñònh nghóa (UDF) . Baïn coù theå taïo moät UDF ñeå traû veà moät giaù trò voâ höôùng (moät giaù trò ñôn) hoaëc moät baûng .
Caùc haøm voâ höôùng :
Haàu heát caùc haøm khoâng phöùc taïp ñeå taïo vaø laøm vieäc vôùi caùc haøm voâ höôùng .
Cuù phaùp :
CREATE FUNCTION [owner_name.]function_name
([{@parameter_name scalar_parameter_data_type [= default]} [ … , n]])
RETURN scalar_returnt_data_type
[WITH ENCRYPTION | SCHEMABINDING] [ AS ]
RETUNR [ ( ] select_statement [ ) ]
Caùc haøm Inline Table – Value :
So vôùi hai haøm cuûa baûng , haøm inline table – value ñôn giaûn hôn :
Cuù phaùp :
CREATE FUNCTION [owner_name.]function_name
([{@parameter_name scalar_parameter_data_type [= default]} [ … , n]])
RETURN TABLE
[WITH ENCRYPTION | SCHEMABINDING] [ AS ]
RETUNR [ ( ] select_statement [ ) ]
Caùc haøm Multistatement Table – Value :
Baïn söû duïng caùc haøm multistatement table – Value ñeå traû veà moät baûng
Cuù phaùp :
CREATE FUNCTION [owner_name.]function_name
([{@parameter_name scalar_parameter_data_type [= default]} [ … , n]])
RETURN @return_variable TABLE Table_type_definition
[WITH ENCRYPTION | SCHEMABINDING] [ AS ]
BEGIN
Function_body
Return [ ( ]select_statement[ ) ]
END
RETUNR [ ( ] select_statement [ ) ]
PHAÀN II. PHAÂN TÍCH THIEÁT KEÁ VAØ CAØI ÑAËT CHÖÔNG TRÌNH
PHAÂN TÍCH ÑEÀ TAØI :
Ñaët taû sô löôïc heä thoáng xaây döïng chöông trình thi traéc nghieäm :
Hieän nay , hình thöùc thi traéc nghieäm ñaõ ñöôïc Boä Giaùo Duïc vaø ñaøo taïo khuyeán khích ñöa vaøo söû duïng trong caùc tröôøng , lôùp . Toå chöùc caùc cuoäc thi traéc nghieäm nhö theá raát caàn thieát ñeå ñaùnh giaù ñuùng khaû naêng vaø kieán thöùc cuûa hoïc vieân .
Heä thoáng naøy seõ taïo ra coâng cuï cho Giaùo Vieân soaïn caâu hoûi traéc nghieäm vaø coâng cuï hoå trôï Giaùo Vieân soaïn ñeà thi . Sinh Vieân seõ thi tröïc tieáp treân maùy Client vaø heä thoáng seõ töï chaám ñieåm . Ñieåm thi seõ ñöôïc heä thoáng coâng boá lieàn hoaëc ñöôïc coâng boá sau . Giaùo Vuï seõ leân danh saùch sinh vieân döï thi cuûa caùc moân thi vaø qui ñònh boä ñeà thi cuûa sinh vieân laáy töø ngaân haøng ñeà thi . Neáu Giaùo Vuï khoâng qui ñònh boä ñeà thi thì sinh vieân seõ thi tröïc tieáp töø ngaân haøng ñeà . Sinh Vieân ñeán döï thi ñuùng lòch thi , vaø thi tröïc tieáp treân maùy tính Client . Sau khi thi xong heä thoáng seõ tính toaùn ñieåm thi , caäp nhaät ñieåm thi vaø baøi laøm cuûa sinh vieân vaøo cô sôû döõ lieäu treân maùy . Ñeå ñaûm baûo tính coâng baèng cuûa cuoäc thi , caùc ñeà thi cuûa sinh vieân ñeàu ñöôïc heä thoáng hoaùn ñoåi ngaãu nhieân vò trí caùc caâu hoûi vaø caâu traû lôøi cuûa ñeà thi ñoù .
Sau khi thi xong döõ lieäu ñöôïc caäp nhaät veà Sever
SEVER
Chöùa CSDL cuûa chöông trình
Thí sinh tieán haønh thi traéc nghieäm treân caùc CLIENT
Phaân tích heä thoáng Thi Traéc Nghieäm baèng Rational Rose :
Xaây döïng Use_Case Diagram :
Nhaän dieän caùc actor vaø caùc tröôøng hôïp söû duïng :
Qua ñaët taû heä thoáng ôû treân ta xaùc ñònh caùc actor sau taùc ñoäng ñeán heä thoáng :
Giaùo Vieân , Sinh Vieân , Giaùo Vuï , Ngöôøi quaûn lyù thoâng soá heä thoáng
Sô ñoà Use_Case diagram cho töøng actor :
Xaây döïng Class Diagram :
Nhaän dieän caùc ñoái töôïng /lôùp vaø caùc Package:
Heä thoáng naøy deã daøng nhaän thaáy nhöõng ñoái töôïng : Sinh vieân , Giaùo vieân , GiaùoVieânDaïy , Lôùp , Moân ,KyøThi , CaâuHoûi , CaâuTraûLôøi ,ÑeàThi ,Caâu Hoûi Ñeà Thi , BoäÑeàRaThi ,Caâu Traû Lôøi Ñeà Thi , DSSVDöïThi , CaâuHoûiBaøiLaøm , CaâuTraûLôøiBaøiLaøm , GiaùoVieânCoiThi , Users , Groups . Ngoaøi ra coøn coù caùc ñoái töôïng taïo ra cöûa soå giao tieáp vôùi caùc Actor coù stereotype laø > :
+ Lôùp LoginForm taïo cöûa soå ñeå Actor truy caäp theo quyeàn cuûa mình .
+ Lôùp MainFormtaïo cöûa soå Menu chính .
+ Lôùp DanhMuïcMoânHoïc Form taïo cöûa soå ñeå Actor xem danh muïc moân hoïc
+ Lôùp QuaûnLyùDanhMuïcMoânHoïc Form taïo cöûa soå ñeå Actor chænh söûa moân hoïc
+ Lôùp DanhMuïcLôùpHoïcFormtaïo cöûa soå ñeå Actor xem danh muïc lôùp .
+ Lôùp QuaûnLyùDanhMuïcLôùpHoïcForm taïo cöûa soå ñeå Actor chænh söûa lôùp hoïc .
+ Lôùp DanhSaùchSinhVieânForm taïo cöûa soå ñeå Actor xem danh saùch SinhVieân
+ Lôùp QuaûnLyùDanhSaùchSinhVieânForm taïo cöûa soå ñeå Actor chænh söûa DSSV
+ Lôùp DanhSaùchGiaùoVieânForm taïo cöûa soå ñeå Actor xem DSGV
+ Lôùp QuaûnLyùDanhSaùchGiaùoVieânForm taïo cöûa soå ñeå Actor chænh söûa GiaùoVieân
+ Lôùp QuaûnLyùMoânDaïyGiaùoVieânForm taïo cöûa soå ñeå Actor chænh söûa Moân cuûa GV
+ Lôùp DanhMuïcCaâuHoûiForm taïo cöûa soå ñeå Actor xem danh muïc caâu hoûi
+ Lôùp QuaûnLyùDanhMuïcCaâuHoûiForm taïo cöûa soå ñeå Actor chænh söûa caâu hoûi
+ Lôùp DanhMuïcÑeàThiForm taïo cöûa soå ñeå Actor xem danh muïc ñeà thi
+ Lôùp QuaûnLyùDanhMuïcÑeàThiForm taïo cöûa soå ñeå Actor chænh söûa ñeà thi
+ Lôùp TaïoÑeàThiForm taïo cöûa soå ñeå Actor taïo ñeà thi .
+ Lôùp DanhMuïcKyøThiForm taïo cöûa soå ñeå Actor xem danh muïc kyø thi
+ Lôùp QuaûnLyùDanhMuïcKyøThiForm taïo cöûa soå ñeå Actor chænh söûa kyø thi
+ Lôùp DanhSaùchSinhVieânDöïThiForm taïo cöûa soå ñeå Actor xem DSSV döï thi
+ Lôùp QuaûnLyùDanhSaùchSinhVieânDöïThiForm taïo cöûa soå ñeå Actor chænh söûa DSSV döï thi
+ Lôùp DanhMuïcBoäÑeàThiForm taïo cöûa soå ñeå Actor xem danh muïc boä ñeà thi
+ Lôùp QuaûnLyùDanhMuïcBoäÑeàThiForm taïo cöûa soå ñeå Actor chænh söûa boä ñeà thi
+ Lôùp DanhSaùchGiaùoVieânCoiThiForm taïo cöûa soå ñeå Actor xem DSGV coi thi
+ Lôùp QuaûnLyùDanhSaùchGiaùoVieânCoiThiForm taïo cöûa soå ñeå Actor chænh söûa DSGV coi thi
+ Lôùp KeátQuaûThiForm taïo cöûa soå ñeå Actor xem keát quaû thi
+ Lôùp BaøiLaømSinhVieânForm taïo cöûa soå ñeå Actor xem baøi laøm sinh vieân
+ Lôùp ÑoåiMaätKhaåuForm taïo cöûa soå ñeå Actor ñoåi maät khaåu
+ Lôùp QuaûnLyùThoângSoáForm taïo cöûa soå ñeå Actor chænh söûa thoâng soá heä thoáng
+ Lôùp LòchThiForm taïo cöûa soå ñeå Actor xem lòch thi
+ Lôùp ThiForm taïo cöûa soå ñeå Actor laøm baøi thi .
+ Lôùp ÑaêngKyùThiForm taïo cöûa soå ñeå Actor ñaêng kyù döï thi
Ngoaøi ra coøn xuaát hieän lôùp Database coù stereotype laø > coù chöùc naêng giao tieáp vôùi cô sôû döõ lieäu ñeå thöïc hieän caùc taùc vuï caäp nhaät döõ lieäu
Class Diagram:
Nhaän dieän caùc moái quan heä giöõa caùc lôùp:
Quan heä giöõa caùc lôùp giao dieän vôùi lôùp Database laø dependency . Söû duïng caùc stereotype > giöõa LoginForm vôùi caùc lôùp giao dieän khaùc . Trong khi quan heä dependency giöõa chuùng coù tereo laø > . Ta taïo ra 2 packge laø :
* Packge Interface ñeå quaûn lyù taát caû caùc giao dieän giao tieáp vôùi ngöôøi duøng goàm hai class diagram chính laø :
+ Class diagram QuaûnLyùDöõLieäu goàm taát caû caùc giao dieän coù lieân quan ñeán cô sôû döõ lieäu vaø chöùa caùc lôùp : Login Form , Main From , Danh Muïc Moân Hoïc Form , Quaûn Lyù Danh Muïc Moân Hoïc Form , Danh Muïc Lôùp Hoïc Form , Quaûn Ly ùDanh Muïc Lôùp Hoïc Form , Danh Saùch Sinh Vieân Form , Quaûn Lyù Danh Saùch Sinh Vieân Form , Danh Saùch Giaùo Vieân Form , Quaûn Lyù Danh Saùch Giaùo Vieân Form , Quaûn Lyù Moân Daïy Giaùo Vieân Form , Danh Muïc Caâu Hoûi Form , Quaûn Lyù Danh Muïc Caâu Hoûi Form , Danh Muïc Ñeà Thi Form , Quaûn Lyù Danh Muïc Ñeà Thi Form , Taïo Ñeà Thi Form , Danh Muïc Kyø Thi Form , Quaûn Lyù Danh Muïc Kyø Thi Form , Danh Saùch Sinh Vieân Döï Thi Form , Quaûn Lyù Danh Saùch Sinh Vieân Döï Thi Form , Danh Muïc Boä Ñeà Thi Form , Quaûn Lyù Danh Muïc Boä Ñeà Thi Form , Danh Saùch Giaùo Vieân Coi Thi Form , Quaûn Lyù Danh Saùch Giaùo Vieân Coi Thi Form , Baøi Laøm Sinh Vieân Form , Quaûn Lyù Thoâng Soá Form
+ Class diagram Thi goàm caùc giao dieän cho Sinh Vieân thi vaø chöùa caùc lôùp :
ÑoåiMaätKhaåuForm , KeátQuaûThiForm , LòchThiForm , ThiForm , ÑaêngKyùThiForm
* Packge Data goàm : SinhVieân,GiaùoVieân,GiaùoVieânDaïy,Lôùp,Moân,KyøThi,Caâu Hoûi,CaâuTraûLôøi,ÑeàThi,CaâuHoûiÑeàThi,BoäÑeàRaThi,CaâuTraûLôøiÑeàThi,DSSVDöï Thi,CaâuHoûiBaøiLaøm,CaâuTraûLôøiBaøiLaøm,GiaùoVieânCoiThi,Users,Groups .
Sô ñoà class diagram :
+ Sô ñoà Class diagram cuûa package Data :
+ Sô ñoà Class diagram cuûa Quaûn Lyù Döõ Lieäu trong package Interface :
+ Sô ñoà Class diagram Sinh Vieân thi trong package Interface :
Xaây döïng Sequence Diagram :
Caùc Sequence Diagram cuûa GiaùoVuï :
Xeùt UseCase QuaûnLyùBoäÑeàThi:
Giaùo vuï ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo vuï seõ choïn form QuaûnLyùBoäÑeàThi.
Trong Form QuaûnLyùBoäÑeàThi Giaùo Vuï seõ choïn Kyø Thi , Moân Thi , Giaùo Vieân ra ñeà thi. Heä thoáng load caùc ñeà thi leân form.Giaùo Vuï seõ choïn caùc ñeà thi ra thi . Giaùo Vuï hoaøn thaønh vieäc choïn thì heä thoáng seõ löu laïi caùc ñeà thi vöøa môùi choïn vaøo Boä ñeà thi trong cô sôû döõ lieäu .
+ Sequence Diagram QuaûnLyùBoäÑeàThi:
Xeùt UseCase QuaûnLyùDSSVDöïThi:
Giaùo vuï ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo vuï seõ choïn form QuaûnLyùDSSVDöï Thi . Giaùo vuï seõ choïn Moân , choïn kyø thi , nhaäp ngaøy giôø vaø choïn caùc sinh vieân döï thi . Heä thoáng seõ theâm danh saùch Sinh Vieân döï thi vaøo cô sôû döõ lieäu.
+ Sequence Diagram QuaûnLyùDSSVDöïThi :
Xeùt UseCase TheâmSV:
Giaùo vuï ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo vuï seõ choïn form QuaûnLyùDanhSaùch SinhVieân . Giaùo vuï seõ nhaäp maõ soá sinh vieân , hoï , teân , phaùi , ñòa chæ, Ngaøy sinh , username , password vaø choïn lôùp cuûa sinh vieân . Heä thoáng seõ theâm SV vaøo CSDL.
+ Sequence Diagram TheâmSV :
Xeùt UseCase SöûaThoângTinSV:
Giaùo vuï ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo vuï seõ choïn form Quaûn Lyù Sinh Vieân . Giaùo vuï choïn Sinh Vieân caàn söûa vaø nhaäp laïi thoâng tin SV goàm : Maõ Soá Sinh Vieân , Hoï , Teân , Phaùi , Ñòa Chæ, Ngaøy inh , username , password vaø choïn lôùp cuûa sinh vieân Heä thoáng seõ caäp nhaät laïi Sinh Vieân naøy vaøo cô sôû döõ lieäu.
+ Sequence Diagram SöûaThoângTinSV
Xeùt UseCase QuaûnLyùDSGVCoiThi :
Giaùo vuï ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo vuï seõ choïn form QuaûnLyùDSGVCoiThi . Giaùo vuï seõ choïn kyø thi vaø choïn caùc Giaùo Vieân coi thi . Heä thoáng seõ theâm danh saùch Giaùo Vieân coi thi vaøo cô sôû döõ lieäu.
+ Sequence Diagram QuaûnLyùDSGVCoiThi
Caùc Sequence Diagram cuûa GiaùoVieân :
Xeùt UseCase ÑoåiMaätKhaåu:
Giaùo Vieân ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo Vieân seõ choïn form ÑoåiMaätKhaåu
Giaùo vieân nhaäp maät khaåu môùi . Heä thoáng seõ caäp nhaät laïi Giaùo Vieân naøy vaøo cô sôû döõ lieäu.
+ Sequence Diagram ÑoåiMaätKhaåu :
Xeùt UseCase TheâmCaâuHoûi:
Giaùo Vieân ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo Vieân seõ choïn form Quaûn Lyù Danh Muïc Caâu Hoûi.Giaùo Vieân choïn Moân , heä thoáng seõ kieåm tra moân naøy Giaùo Vieân coù daïy khoâng . Neáu coù Giaùo Vieân seõ nhaäp thoâng tin Caâu hoûi . Heä thoáng seõ theâm Caâu Hoûi vaøo cô sôû döõ lieäu .
+ Sequence Diagram TheâmCaâuHoûi :
Xeùt UseCase Xoùa Caâu Hoûi :
Giaùo Vieân ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo Vieân seõ choïn form Quaûn Lyù Caâu Hoûi . Giaùo vieân seõ choïn caâu hoûi caàn xoùa . Heä thoáng seõ kieåm tra cho xoùa khoâng , vaø thoâng baùo cho Giaùo vieân . Neáu heä thoáâng cho pheùp vaø Giaùo vieân ñoàng yù thì heä thoáng seõ xoùa Caâu Hoûi naøy trong CSDL .
+ Sequence Diagram Xoùa Caâu Hoûi :
Xeùt UseCase TheâmÑeàThi
Giaùo Vieân ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form Mainenu seõ ñöôïc kích hoaït , töø form naøy Giaùo Vieân seõ choïn form TheâmÑeàThi Giaùo vieân seõ choïn Moân vaø nhaäp thoâng tin ñeà thi . Heä thoáng seõ phaùt sinh ñeà theo yeâu caàu cuûa Giaùo Vieân vaø sau ñoù theâm Ñeà Thi naøy vaøo cô sôû döõ lieäu .
+ Sequence Diagram TheâmÑeàThi
Caùc Sequence Diagram cuûa SinhVieân :
Xeùt UseCase Thi :
Sinh Vieân ñaêng nhaäp vaøo heä thoáng baèng username vaø password cuûa mình . Heä thoáng seõ kieåm tra trong cô sôû döõ lieäu vieäc ñaêng nhaäp coù hôïp leä khoâng vaø neáu hôïp leä form MainMenu seõ ñöôïc kích hoaït , töø form naøy Sinh Vieân seõ choïn form Ñaêng Kyù Thi. Sinh vieân choïn moân , choïn kyø thi . Heä thoáng seõ kieåm tra xem Sinh Vieân naøy coù ñöôïc thi hay khoâng . Neáu ñöôïc thì heä thoáng seõ kích hoaït From thi .Sau khi hoaøn taát baøi thi , heä thoáng seõ tính ñieåm vaø löu baøi thi vaøo cô sôû döõ lieäu.
+ Sequence Diagram Thi :
Choïn moâ hình caøi ñaët veà cô sôû döõ lieäu :
Coù hai phöông phaùp löïa choïn : Döõ lieäu taäp trung vaø döõ lieäu phaân taùn . Ta choïn phöông phaùp cô sôû döõ lieäu taäp trung vì :
+ Khoái löôïng döõ lieäu khoâng lôùn
+ Soá löôïng thí sinh vaø giaùo vieân chuû yeáu taäp trung trong phaïm vi nhaø tröôøng .
+ Quaûn lyù ñaøo taïo taïi nöôùc ta vaãn laø hình thöùc taäp trung taïi moät cô sôû chính . Neáu coù nhieàu cô sôû thöôøng thì chæ trong baùn kính nhoû .
THIEÁT KEÁ CHÖÔNG TRÌNH
SQL Server 2000 thích hôïp ñeå laøm DBMS cho chöông trình naøy vì :
+ Cô sôû döõ lieäu ôû ñaây trung bình .
+ SQL Server 2000 coù theå chaïy trong caùc heä ñieàu haønh Windows NT 4.0 (töø Srevice Pack 5 trôû ñi) , Windows 2000 , Windows 98 hoaëc Windows Me vaø coù theå söû duïng vôùi heä ñieàu haønh Windows CE .
+ SQL Server cuûa Microsoft laø moät phöông tieän cô sôû döõ lieäu Client/Server .
Töø ñieån döõ lieäu :
SINHVIENID
Maõ Sinh Vieân
MASINHVIEN
Maõ soá Sinh Vieân
LOPID
Maõ Lôùp
HO
Hoï
TEN
Teân
PHAI
Phaùi
NGAYSINH
Ngaøy Sinh
DIACHI
Ñòa Chæ
MALOP
Maõ Soá Lôùp
TENLOP
Teân Lôùp
MONID
Maõ Moân
MAMON
Maõ soá moân
TENMON
Teân moân
SODVHT
Soá ñôn vò hoïc taäp
KYTHIID
Maõ kyø thi
MAKYTHI
Maõ soá kyø thi
TENKYTHI
Teân kyø thi
GIAOVIEÂNID
Maõ Giaùo Vieân
MAGIAOVIEN
Maõ soá GV
DIENTHOAI
Ñieän Thoïai
CHUCDANH
Chöùc Danh
ACTIVE
Nghó/coøn daïy
CAUHOIID
Maõ caâu hoûi
NOIDUNG
Noäi dung
MUCDO
Möùc ñoä
DETHIID
Maõ ñeà thi
THOIGIANLAMBAI
Thôøi gian laøm baøi
SOCH
Soá Caâu Hoûi
CAUTRALOIID
Maõ Caâu Traû Lôøi
NOIDUNG
Noäi Dung
STT
Soá thöù töï caâu hoûi
CAUTRALOIIDCHON
Maõ caâu traû lôøi
BAILAMID
Maõ baøi laøm
DIEM
Ñieåm Thi
NGAYTHI
Ngaøy Thi
GROUPID
Maõ nhoùm
TENGROUP
Teân Nhoùm
USERID
Maõ User
USERNAME
Teân Ñaêng Nhaäp
PASSWORDS
Maät Khaåu
CAUTRALOIDUNG
Caâu Traû Lôøi Ñuùng
Moâ taû caùc Table :
SINHVIEN ( SINHVIENID , MASINHVIEN , LOPID , HO , TEN , PHAI , NGAYSINH , DIACHI , USERID)
FieldName
Keys
Data Type
Size
Allow Nulls
SINHVIENID
Khoùa
Numeric
9
MASINHVIEN
Varchar
15
Not null
LOPID
Numeric
9
Not null
HO
Varchar
50
Not null
TEN
Varchar
50
Not null
PHAI
Bit
1
Not null
NGAYSINH
Date/Time
8
Not null
DIACHI
Varchar
50
Null
USERID
Numeric
9
Not null
LOP ( LOPID , MALOP , TENLOP )
Field Name
Keys
Data Type
Size
Allow Nulls
LOPID
Khoùa
Numeric
9
MALOP
Varchar
15
Not null
TENLOP
Varchar
50
Not null
MON (MONID, MAMON , TENMON , SDVHT )
Field Name
Keys
Data Type
Size
Allow Nulls
MONID
Khoùa
Numeric
9
MAMON
Varchar
15
Not null
Ten MON
Varchar
50
Not null
SODVHT
Integer
4
Not null
KYTHI ( KYTHIID , MAKYTHI , TENKYTHI)
Field Name
Keys
Data Type
Size
Allow Nulls
KYTHIID
Khoùa
Numeric
9
MAKYTHI
Varchar
15
Not null
TENKYTHI
Varchar
50
Not null
GIAOVIEN (MAGV ID, MAGIAOVIEN, HO , TEN , PHAI , DIA CHI , DIENTHOAI , CHÖÙC DANH , ACTIVE , UERID )
Field Name
Keys
Data Type
Size
Allow Nulls
GIAOVIEÂNID
Khoùa
Numeric
9
MAGIAOVIEN
Varchar
15
Not null
HO
Varchar
50
Not null
TEN
Varchar
20
Not null
PHAI
Bit
1
Not null
DIACHI
Varchar
50
Not null
DIENTHOAI
Varchar
20
null
CHUCDANH
Varchar
50
Not null
ACTIVE
Bit
1
Not null
USERID
Numeric
9
Not null
GIAOVIENDAY (GIAOVIENID , MONID )
Field Name
Keys
Data Type
Size
Allow Nulls
GIAOVIENID
Khoùa
Numeric
9
Not null
MONID
Khoùa
Numeric
9
Not null
CAUHOI ( CAUHOIID , MONID , GIAOVIENID, NOIDUNG , MUCDO , CAUTRALOIDUNGID )
Field Name
Keys
Data Type
Size
Allow Nulls
CAUHOIID
Khoùa
Numeric
9
MONID
Numeric
9
Not null
GIAOVIENID
Numeric
9
Not null
NOIDUNG
Varchar
200
Not null
MUCDO
Integer
4
Not null
CAUTRALOIDUNGID
Numeric
9
Null
CAUTRALOI ( CAUTRALOIID , CAUHOIID , NOIDUNG )
Field Name
Keys
DataType
Size
Allow Nulls
CAUTRALOIID
Khoùa
Numeric
9
Not null
CAUHOIID
Numeric
9
Not null
NOIDUNG
Varchar
60
Not null
DETHI ( DETHIID , MONID, GIAOVIENID , THOIGIANLAMBAI , SOCH )
Field Name
Keys
DataType
Size
Allow Nulls
DETHIID
Khoùa
Numeric
9
MONID
Numeric
9
Not null
GIAOVIENID
Numeric
9
Not null
THOIGIANLAMBAI
Integer
4
Not null
SOCH
Integer
4
Not null
CAUHOIDETHI ( CAUHOIID , DETHIID , NOIDUNG , MUCDO , CAUTRALOIDUNGID )
Field Name
Keys
Data Type
Size
Allow Nulls
CAUHOIID
Khoùa
Numeric
9
Not null
DETHIID
Numeric
9
Not null
NOIDUNG
Varchar
200
Not null
MUCDO
Integer
4
Not null
CAUTRALOIDUNGID
Numeric
9
Null
BODERATHI ( DETHIID ,KYTHIID )
Field Name
Keys
Data Type
Size
Allow Nulls
DETHIID
Khoùa
Numeric
9
Not null
KYTHIID
Khoùa
Numeric
9
Not null
CAUTRALOIDETHI (CAUTRALOIID , CAUHOIID , NOIDUNG )
Field Name
Keys
Data Type
Size
Allow Nulls
CAUTRALOIID
Khoùa
Numeric
9
Not null
CAUHOIID
Numeric
9
Not null
NOIDUNG
Varchar
60
Not null
CAUHOIBAILAM (BAILAMID , CAUHOIID, STT, CAUTRALOIIDCHON)
Field Name
Keys
Data Type
Size
Allow Nulls
STT
Numeric
9
Not null
CAUHOIID
Khoùa
Numeric
9
Not null
CAUTRALOIIDCHON
Numeric
9
Null
BAILAMID
Khoùa
Numeric
9
Not null
CAUTRALOIBAILAM (STT, CAUTRALOIID, BAILAMID)
Field Name
Keys
Data Type
Size
Allow Nulls
STT
Numeric
9
Not null
CAUTRALOIID
Khoùa
Numeric
9
Not null
BAILAMID
Khoùa
Numeric
9
Not null
DSSVDUTHI ( MONID , SINHVIENID , KYTHIID , BAILAMID , DETHIID , DIEM , NGAYTHI )
Field Name
Keys
Data Type
Size
Allow Nulls
MONID
Khoùa
Numeric
9
Not null
SINHVIENID
Khoùa
Numeric
9
Not null
KYTHIID
Khoùa
Numeric
9
Not null
BAILAMID
Numeric
9
Not null
DETHIID
Numeric
9
Not null
DIEM
Integer
4
Not null
NGAYTHI
Date / time
8
Not null
GROUPS (GROUPID , TENGROUP)
Field Name
Keys
Data Type
Size
Allow Nulls
GROUPID
Khoùa
Numeric
9
TENGROUP
Varchar
50
Not null
USERS ( USERID , USERNAME , PASSWORDS , GROUPID )
Field Name
Keys
Data Type
Size
Allow Nulls
USERID
Khoùa
Numeric
9
Not null
USERNAME
Varchar
50
Not null
PASSWORDS
Varchar
50
Not null
GROUPID
Numeric
9
Not null
GIAOVIENCOITHI (GIAOVIENID , KYTHIID , MONID)
Field Name
Keys
Data Type
Size
Allow Nulls
GIAOVIENID
Khoùa
Numeric
9
Not null
KYTHIID
Khoùa
Numeric
9
Not null
MONID
Khoùa
Numeric
9
Not null
Raøng buoät toaøn veïn :
RBTV coù boái caûnh treân moät löôïc ñoà quan heä
RBTV veà mieàn giaù trò :
R1 : " m Î MON
m.DVHT > 0
Taàm aûnh höôûng :
R1
Theâm
Xoùa
Söûa
MON
+
-
+
R2 : " sv Î SINHVIEN
sv.NGAYSINH < GETDATE ( )
Taàm aûnh höôûng :
R2
Theâm
Xoùa
Söûa
SINHVIEN
+
-
+
R3 : " dt Î DETHI
dt.THOIGIANLAMBAI >0
R4 : " dt Î DETHI
dt.SOCAUHOI >0
Taàm aûnh höôûng :
R3,4
Theâm
Xoùa
Söûa
DETHI
+
-
+
R 5 : " d Î DSSVDUTHI
d.DIEM BETWEEN 0 AND 10
R 6 : " d Î DSSVDUTHI
d.NGAYTHI > = GETDATE ( )
Taàm aûnh höôûng :
R5,6
Theâm
Xoùa
Söûa
DSSVDUTHI
+
-
+
R 7 : " ch Î CAUHOI
ch.MUCDO BETWEEN 1 AND 3
( MUCDO = 1 : Khoù , 2: Trung Bình , 3: Deã )
Taàm aûnh höôûng :
R7
Theâm
Xoùa
Söûa
CAUHOI
+
-
+
R 8 : " chdt Î CAUHOIDETHI
chdt.MUCDO BETWEEN 1 AND 3
( MUCDO = 1 : Khoù , 2: Trung Bình , 3: Deã )
Taàm aûnh höôûng :
R8
Theâm
Xoùa
Söûa
CAUHOIDETHI
+
-
+
RBTV lieân boä (khoùa noäi ) :
R9 : " sv1 ¹ sv2 Î SINHVIEN
sv1.SINHVIENID ¹ sv2.SINHVIENID
R10 : " sv1 ¹ sv2 Î SINHVIEN
sv1.MASINHVIEN ¹ sv2.MASINHVIEN
R11 : " sv1 ¹ sv2 Î SINHVIEN
sv1.USERID ¹ sv2.USERID
R12 : " lop1 ¹ lop2 Î LOP
lop1.LOPID ¹ lop2.LOPID
R13 : " lop1 ¹ lop2 Î LOP
lop1.MALOP ¹ lop2.MALOP
R14 : " m1 ¹ m2 Î MON
m1.MONID ¹ m2.MONID
R15 : " m1 ¹ m2 Î MON
m1.MAMON ¹ m2.MAMON
R16 : " k1 ¹ k2 Î KYTHI
k1.KYTHIID ¹ m2.KYTHIID
R17 : " k1 ¹ k2 Î KYTHI
k1.MAKYTHI ¹ m2.MAKYTHI
R18 : " gv1 ¹ gv2 Î GIAOVIEN
gv1. GIAOVIENID ¹ gv2. GIAOVIENID
R19 : " gv1 ¹ gv2 Î GIAOVIEN
gv1.MAGIAOVIEN ¹ gv2.MAGIAOVIEN
R20 : " gv1 ¹ gv2 Î GIAOVIEN
gv1.USERID ¹ gv2.USERID
R21 : " gvd1 ¹ gvd2 Î GIAOVIENDAY
gvd1.GIAOVIENID ¹ gvd2.GIAOVIENID OR
gvd1.MONID ¹ gvd2.MONID
R22 : " ch1 ¹ ch2 Î CAUHOI
ch1.CAUHOIID ¹ ch2.CAUHOIID
R23 : " ctl1 ¹ ctl2 Î CAUTRALOI
ctl1. CAUTRALOIID ¹ ctl2.CAUTRALOIID
R24 : " dt1 ¹ dt2 Î DETHI
dt1. DETHIID ¹ dt2.DETHIID
R25 : " chdt1 ¹ chdt2 Î CAUHOIDETHI
chdt1.CAUHOIID ¹ ch2dt.CAUHOIID
R26 : " bd1 ¹ bd2 Î BODERATHI
bd1.DETHIID ¹ bd2.DETHIID OR
bd1.KYTHIID ¹ bd2.KYTHIID
R27 : " ctldt1 ¹ ctldt2 Î CAUTRALOIDETHI
ctldt1. CAUTRALOIID ¹ ctldt2.CAUTRALOIID
R28 : " chbl1 ¹ chbl2 Î CAUHOIBAILAM
chbd1.CAUHOIID ¹ chbd2.CAUHOIID OR
chbd1.BAILAMID ¹ chbd2.BAILAMID
R29 : " chbl1 ¹ chbl2 Î CAUHOIBAILAM
chbd1.STT ¹ chbd2.STT OR
chbd1.BAILAMID ¹ bd2.BAILAMID
R30 : " ctlbl1 ¹ ctlbl2 Î CAUTRALOIBAILAM
chtld1.CAUTRALOIID ¹ chbd2. CAUTRALOIID OR
ctlbd1.BAILAMID ¹ ctlbd2.BAILAMID
R31 : " dssvdt1 ¹ dssvdt2 Î DSSVDUTHI
dssvdt1.MONID ¹ dssvdt2. MONID OR
dssvdt1.SINHVIENID ¹ dssvdt2.SINHVIENID OR
dssvdt1.KYTHIID ¹ dssvdt2. KYTHIID
R32 : " dssvdt1 ¹ dssvdt2 Î DSSVDUTHI
dssvdt1.BAILAMID ¹ dssvdt2. BAILAMID
R33 : " gvct1 ¹ gvct2 Î GIAOVIENCOITHI
gvct1.GIAOVIENID ¹ gvct2. GIAOVIENID OR
gvct1.KYTHIID ¹ gvct2. KYTHIID OR
gvct1.MONID ¹ gvct2. MONID
R34 : " u1 ¹ u2 Î USERS
u1.USERID ¹ u2.USERID
R35 : " u1 ¹ u2 Î USERS
u1.USERNAME ¹ u2.USERNAME
R36 : " g1 ¹ g2 Î GROUPS
g1. GROUPID ¹ g2. GROUPID
RBTV coù boái caûnh treân nhieàu löôïc ñoà quan heä
RBTV phuï thuoäc toàn taïi (khoùa ngoaïi ) :
R37 : " sv Î SINHVIEN
$ lop Î LOP : sv.LOPID = lop.LOPID
Taàm aûnh höôûng :
R37
Theâm
Xoùa
Söûa
SINHVIEN
+
-
+
LOP
-
+
+
R38 : " sv Î SINHVIEN
$ u Î USERS : sv.USERID = u.USERID
Taàm aûnh höôûng :
R38
Theâm
Xoùa
Söûa
SINHVIEN
+
-
+
USERS
-
+
+
R39 : " gv Î GIAOVIEN
$ u Î USERS : gv.USERID = u.USERID
Taàm aûnh höôûng :
R39
Theâm
Xoùa
Söûa
GIAOVIEN
+
-
+
USERS
-
+
+
R40 : " gvd Î GIAOVIENDAY
$ gv Î GIAOVIEN : gvd.GIAOVIENID = gv.GIAOVIENID
Taàm aûnh höôûng :
R40
Theâm
Xoùa
Söûa
GIAOVIENDAY
+
-
+
GIAOVIEN
-
+
+
R41 : " gvd Î GIAOVIENDAY
$ m Î MON : gvd.MONID = m.MONID
Taàm aûnh höôûng :
R41
Theâm
Xoùa
Söûa
GIAOVIENDAY
+
-
+
MON
-
+
+
R42 : " ch Î CAUHOI
$ gv Î GIAOVIEN : ch.GIAOVIENID = gv.GIAOVIENID
Taàm aûnh höôûng :
R42
Theâm
Xoùa
Söûa
CAUHOI
+
-
+
GIAOVIEN
-
+
+
R43 : " ch Î CAUHOI
$ m Î MON : ch.MONID = m.MONID
Taàm aûnh höôûng :
R43
Theâm
Xoùa
Söûa
CAUHOI
+
-
+
MON
-
+
+
R44 : " ctl Î CAUTRALOI
$ ch Î CAUHOI : ctl.CAUHOIID = ch.CAUHOIID
Taàm aûnh höôûng :
R44
Theâm
Xoùa
Söûa
CAUTRALOI
+
-
+
CAUHOI
-
+
+
R45 : " dt Î DETHI
$ gv Î GIAOVIEN : dt.GIAOVIENID = gv.GIAOVIENID
Taàm aûnh höôûng :
R45
Theâm
Xoùa
Söûa
DETHI
+
-
+
GIAOVIEN
-
+
+
R46 : " dt Î DETHI
$ m Î MON : dt.MONID = m.MONID
Taàm aûnh höôûng :
R46
Theâm
Xoùa
Söûa
DETHI
+
-
+
MON
-
+
+
R47 : " chdt Î CAUHOIDETHI
$ dt Î DETHI : chdt.DETHIID = dt.DETHIID
Taàm aûnh höôûng :
R47
Theâm
Xoùa
Söûa
CAUHOIDETHI
+
-
+
DETHI
-
+
+
R48 : " bd Î BODERATHI
$ dt Î DETHI : bd.DETHIID = dt.DETHIID
Taàm aûnh höôûng :
R48
Theâm
Xoùa
Söûa
BODERATHI
+
-
+
DETHI
-
+
+
R49 : " bd Î BODERATHI
$ kt Î KYTHI : bd.KYTHIID = kt.KYTHIID
Taàm aûnh höôûng :
R49
Theâm
Xoùa
Söûa
BODERATHI
+
-
+
KYTHI
-
+
+
R50 : " ctldt Î CAUTRALOIDETHI
$ chdt Î CAUHOIDETHI : ctldt.CAUHOIID = chdt.CAUHOIID
Taàm aûnh höôûng :
R50
Theâm
Xoùa
Söûa
CAUTRALOIDETHI
+
-
+
CAUHOIDETHI
-
+
+
R51 : " dssv Î DSSVDUTHI
$ m Î MON : dssv.MONID = m.MONID
Taàm aûnh höôûng :
R51
Theâm
Xoùa
Söûa
DSSVDUTHI
+
-
+
MON
-
+
+
R52 : " dssv Î DSSVDUTHI
$ sv Î SINHVIEN : dssv.SINHVIENID = sv.SINHVIENID
Taàm aûnh höôûng :
R52
Theâm
Xoùa
Söûa
DSSVDUTHI
+
-
+
SINHVIEN
-
+
+
R53 : " dssv Î DSSVDUTHI
$ kt Î KYTHI : dssv.KYTHIID = kt.KYTHIID
Taàm aûnh höôûng :
R53
Theâm
Xoùa
Söûa
DSSVDUTHI
+
-
+
KYTHI
-
+
+
R54 : " dssv Î DSSVDUTHI
IF dssv.DETHIID ¹ NULL THEN
$ dt Î DETHI : dssv.DETHIID = dt.DETHIID
END IF
Taàm aûnh höôûng :
R54
Theâm
Xoùa
Söûa
DSSVDUTHI
+
-
+
DETHIID
-
+
+
R55 : " gvct Î GIAOVIENCOITHI
$ kt Î KYTHI : gvct.KYTHIID = kt.KYTHIID
Taàm aûnh höôûng :
R55
Theâm
Xoùa
Söûa
GIAOVIENCOITHI
+
-
+
KYTHI
-
+
+
R56 : " gvct Î GIAOVIENCOITHI
$ gv Î GIAOVIEN : gvct.GIAOVIENID = gv.GIAOVIENID
Taàm aûnh höôûng :
R56
Theâm
Xoùa
Söûa
GIAOVIENCOITHI
+
-
+
GIAOVIEN
-
+
+
R65 : " gvct Î GIAOVIENCOITHI
$ m Î MON : gvct.MONID = m.MONID
Taàm aûnh höôûng :
R65
Theâm
Xoùa
Söûa
GIAOVIENCOITHI
+
-
+
MON
-
+
+
R57 : " chbl Î CAUHOIBAILAM
$ chdt Î CAUHOIDETHI : chbl.CAUHOIID = chdt.CAUHOIID
Taàm aûnh höôûng :
R57
Theâm
Xoùa
Söûa
CAUHOIBAILAM
+
-
+
CAUHOIDETHI
-
+
+
R58 : " chbl Î CAUHOIBAILAM
$ dssv Î DSSVDUTHI : chbl.BAILAMID = dssv.BAILAMID
Taàm aûnh höôûng :
R58
Theâm
Xoùa
Söûa
CAUHOIBAILAM
+
-
+
DSSVDUTHI
-
+
+
R59 : " ctlbl Î CAUTRALOIBAILAM
$ ctldtÎCAUTRALOIDETHI :ctlbl.CAUTRALOIID = ctldt.CAUTRALOIID
Taàm aûnh höôûng :
R59
Theâm
Xoùa
Söûa
CAUHOIBAILAM
+
-
+
CAUTRALOIDETHI
-
+
+
R60 : " ctlbl Î CAUTRALOIBAILAM
$ dssv Î DSSVDUTHI : ctlbl.BAILAMID = dssv.BAILAMID
Taàm aûnh höôûng :
R60
Theâm
Xoùa
Söûa
CAUTRALOIBAILAM
+
-
+
DSSVDUTHI
-
+
+
R61 : " u Î USERS
$ g Î GROUPS : u.GROUPID = g.GROUPID
Taàm aûnh höôûng :
R61
Theâm
Xoùa
Söûa
USERS
+
-
+
GROUPS
-
+
+
RBTV lieân thuoäc tính lieân quan heä :
R62 : " ch Î CAUHOI
$ ctl Î CAUTRALOI :
ch.CAUTRALOIDUNGID = ctl.CAUTRALOIID
AND ctl.CAUHOIID = ch.CAUHOIID
R63 : " chdt Î CAUHOIDETHI
$ ctldt Î CAUTRALOIDETHI :
chdt.CAUTRALOIDUNGID = ctldt.CAUTRALOIID
AND ctldt.CAUHOIID = chdt.CAUHOIID
R64 : " chbl Î CAUHOIBAILAM
IF chbl.CAUTRALOIIDCHON ¹ NULL THEN
$ ctldt Î CAUTRALOIDETHI :
chbl.CAUTRALOIIDCHON = ctldt.CAUTRALOIID
AND ctldt.CAUHOIID = chbl.CAUHOIID END IF
4. Sô ñoà quan heä ERD:
CAØI ÑAËT CHÖÔNG TRÌNH
Caùc giao dieän chính :
Giao dieän MainMenu quaûn lyù döõ lieäu :
Giao dieän Quaûn Lyù Moân :
Giao dieän Quaûn Lyù Sinh Vieân :
Giao dieän Quaûn Lyù DSSV Döï Thi
Giao dieän Quaûn Lyù Caâu Hoûi :
Giao dieän Taïo Ñeà Thi :
Report In Baûng Ñieåm :
Giao dieän MainMenu Sinh Vieân :
Giao dieän Thi
PHAÀN III. TOÅNG KEÁT
NHAÄN XEÙT CHUNG :
Ñaùnh giaù keát quaû cuûa chöông trình
Qua quaù trình nghieân cöùu , hoïc hoûi vaø xaây döïng chöông trình Thi Traéc Nghieäm , chöông trình ñaõ ñaït ñöôïc moät soá keát quaû laø :
+ Hoå trôï Giaùo Vieân soaïn Caâu Hoûi vaø taïo Ñeà Thi theo yeâu caàu .
+ Hoå trôï Sinh Vieân thi treân maùy Client ñöôïc deã daøng hôn vaø ñöôïc xem lòch thi , xem keát quaû thi .
+ Trong quaù trình Sinh Vieân thi treân maùy , Giaùm Thò Coi Thi coù theå can thieäp tröïc tieáp vaøo baøi laøm cuûa Sinh Vieân ( caám thi , huûy baøi thi , taïm ngöng thôøi gian thi cuûa Sinh vieân , cho Sinh Vieân tieáp tuïc thôøi gian thi cuûa mình ) neáu Sinh Vieân hoaëc baøi laøm cuûa Sinh Vieân ñoù coù vaán ñeà .
+ Giaùo Vuï ñöôïc hoå trôï nhieàu taùc vuï veà nghieäp vuï nhö quaûn lyù Giaùo Vieân , Sinh Vieân , Moân Hoïc , Lôùp vaø toå chöùc moät Kyø Thi bao goàm caùc coâng vieäc : leân danh saùch Sinh Vieân Döï Thi , quy ñònh caùc Ñeà Ra Thi , leân danh saùch Giaùo Vieân Coi Thi .
+ Vaø vôùi chöông trình Thi Traéc Nghieäm naøy Giaùo Vieân khoâng coøn phaûi chaám töøng baøi thi cuûa SV baèng tay nöõa , maø heä thoáng seõ töï chaám ñieåm vaø in baûng ñieåm ra theo yeâu caàu .
+ Ñeå phaân bieät ñöôïc ngöôøi söû duïng heä thoáng , ngöôøi söû duïng ñaêng nhaäp vaøo heä thoáng baèng teân ñaêng nhaäp vaø maät khaåu rieâng cuûa mình , vaø ñeå baûo maät caùc maät khaåu cuûa ngöôøi söû duïng ñöïôc an toaøn , heä thoáng seõ maõ hoùa maät khaåu tröôùc khi löu vaøo cô sôû döõ lieäu.
Haïn cheá cuûa chöông trình :
Trong thôøi gian ngaén , vôùi taát caû söï noå löïc cuûa chuùng em ñeå hoaøn thaønh ñeà taøi naøy .Tuy ñaït ñöôïc nhöõng keát quaû cuï theå nhöng vaãn khoâng traùnh khoûi nhöõng thieáu soùt , haïn cheá , vaø coøn toàn taïi vaán ñeà chöa giaûi quyeát toát caàn ñöôïc goùp yù boå sung theâm .
Ngoaøi ra do kieán thöùc vaø kinh nghieäm haïn heïp neân ñeà taøi muoán phaùt trieån theâm thì caàn coù thôøi gian ñeå tieáp tuïc nghieân cöùu , tieáp thu yù kieán ñoùng goùp vaø hoaøn thieän veà maët kyõ thuaät ñeå chöông trình coù theå trôû thaønh moät öùng duïng toát vaø ñaït hieäu quaû cao.
HÖÔÙNG PHAÙT TRIEÅN CHÖÔNG TRÌNH :
Vôùi ñeà taøi naøy chuùng ta coù theå phaùt trieån theâm :
+ Môû roäng phaïm vi soaïn thaûo ñeà thi cuûa Giaùo Vieân baèng moät trình soaïn thaûo naøo ñoù vaø löu vaøo file , chöông trình seõ töï ñoäng keát noái file ñoù vaøo cô sôû döõ lieäu
+ Caâu Hoûi boå sung theâm hình aûnh minh hoïa .
+ In ñeà thi vaø cho Sinh Vieân thi treân giaáy .
+ Thay ñoåi quyeàn söû duïng heä thoáng moät caùch linh ñoäng
KEÁT LUAÄN
Söï phaùt trieån maïnh meû cuûa Coâng Ngheä Thoâng Tin cuøng vôùi söï ñoøi hoûi ngaøy caøng cao söï töï ñoäng hoùa , tin hoïc hoùa cuûa con ngöôøi vaøo taát caû caùc lænh vöïc khieán cho xaõ hoäi luoân ñoåi môùi . Qua quaù trình tìm hieåu , nghieân cöùu vaø aùp duïng nhöõng coâng ngheä môùi cuûa lónh vöïc Tin Hoïc trong coâng cuoäc caûi caùch cuûa Boä Giaùo Duïc , chuùng em xaây döïng ñeà taøi naøy vôùi mong muoán ñöôïc goùp moät phaàn coâng söùc vaøo coâng cuoäc ñoåi môùi naøy .
Döïa treân nhöõng maët ñaït ñöôïc vaø chöa ñaït ñöôïc cuûa ñeà taøi , chuùng em hy voïng seõ nhaän ñöôïc nhieàu yù kieán ñoùng goùp , nhaän xeùt ñeå coù ñieàu kieän phaùt trieån öùng duïng naøy leân cao hôn nöõa .
TAØI LIEÄU THAM KHAÛO
[1] TEACH YOURSELF OBJECT- ORIENTED PROGRAMMING WITH VISUAL BASIC.NET IN 21 DAYS
Taùc giaû : Richard J.Simon
NXB : Sam
[2] KYÕ NAÊNG LAÄP TRÌNH VISUAL BASIC.NET
Taùc giaû : Nguyeãn Tieán Duõng
NXB : Nhaø Xuaát Baûn Thoáng Keâ
[3] LAÄP TRÌNH CHUYEÂN SAÂU VISUAL BASIC.NET
Taùc giaû : Phöông Lan
NXB : Nhaø Xuaát Baûn Lao Ñoäng - Xaõ Hoäi
[4] ADO.NET LAÄP TRÌNH VAØ ÖÙNG DUÏNG
Taùc giaû : Nguyeãn Tieán _Nguyeãn Vuõ Thònh
NXB : Nhaø Xuaát Baûn Thoáng Keâ Lao Ñoäng – Xaõ Hoäi
[5] SQL SERVER 2000 DATABASE DESIGN
Taùc giaû : Louis Davidson
NXB : Wrox
[6] MICROSOFT SQL SERVER 2000
Taùc giaû : Nguyeãn Ngoïc Minh_Hoaøng Ñöùc Haûi
NXB : Nhaø Xuaát Baûn Lao Ñoäng – Xaõ Hoäi
[7] VISUAL MODELING WITH RATIONAL ROSE 2000 AND UML
Taùc giaû : Terry Quatrani
NXB : Grady Booch
[8] PHAÂN TÍCH VAØ THIEÁT KEÁ HÖÔÙNG ÑOÁI TÖÔÏNG BAÈNG UML
Taùc giaû : Döông Anh Ñöùc
NXB : Nhaø Xuaát Baûn Thoáng Keâ