4 .2Tạo CSDL với SQL Server
4.2.1 Sơ đồ quan hệ
Hình: Sơ đồ quan hệ
Ràng buộc: Mơ tả ràng buộc của các quan hệ
4.2.2 CHI TIẾT CÁC BẢNG
Mỗi bảng cần viết theo hướng dẫn sau đây:
4.2.2.1 Bảng NhanVien CẤU TRÚC BẢNG
TÊN CỘT KIỂU DỮ LIỆU
MaNV NVARCHAR(20)
MatKhau NVARCHAR(50)
HoTen NVARCHAR(50)
VaiTro BIT
MÃ LỆNH TẠO BẢNG
CREATE TABLE NhanVien
(
MaNV NVARCHAR(50) NOT NULL, MatKhau NVARCHAR(50) NOT NULL, HoTen NVARCHAR(50) NOT NULL, VaiTro BIT NOT NULL,
PRIMARY KEY(MaNV)
)
CÂU LỆNH SQL CƠ BẢN
INSERT INTO NhanVien (MaNV, MatKhau, HoTen, VaiTro) VALUES (?, ?, ?, ?)
UPDATE NhanVien SET MatKhau = ?, HoTen = ?, VaiTro = ? WHERE MaNV = ?
DELETE FROM NhanVien WHERE MaNV = ? SELECT * FROM NhanVien WHERE MaNV = ?
4.2.2.2 Bảng ChuyenDe CẤU TRÚC BẢNG
TÊN CỘT KIỂU DỮ LIỆU
MaCD Nchar(5) TenCD Nvarchar(50) HocPhi Float ThoiLuong Int Hinh Nvarchar(50) MoTa Nvarchar(255) MÃ LỆNH TẠO BẢNG
CREATE TABLE ChuyenDe
(
MaCD NCHAR(5) NOT NULL, TenCD NVARCHAR(50) NOT NULL, HocPhi Float NOT NULL,
ThoiLuong Int NOT NULL,
Hinh NVARCHAR(50) NOT NULL, MoTa NVARCHAR(255) NOT NULL,
PRIMARY KEY(MaCD)
)
CÂU LỆNH SQL CƠ BẢN
INSERT INTO ChuyenDe (MaCD,TenCD, TenCD, ThoiLuong, Hinh, Mota) VALUES (?, ?, ?, ?,?,?)
UPDATE ChuyenDe SET MaCD = ?, TenCD = ?,ThoiLuong = ? , Hinh = ? , Mota = ?
WHERE MaCD = ?
DELETE FROM ChuyenDe WHERE MaCD = ? SELECT * FROM ChuyenDe WHERE MaCD = ?
4.2.2.3 Bảng NguoiHoc CẤU TRÚC BẢNG
TÊN CỘT KIỂU DỮ LIỆU
MANH Nchar(7) HOTEN Nvarchar(50) GIOITINH Bit NGAYSINH Date DIENTHOA Nvarchar(24) I EMAIL Nvarchar(50) GHICHU Nvarchar(255) MANV Nvarchar(20) NgayDK Date
MÃ LỆNH TẠO BẢNG
CREATE TABLE [dbo].[NguoiHoc]( [MaNH] [nchar](7) NOT NULL, [HoTen] [nvarchar](50) NOT NULL, [NgaySinh] [date] NOT NULL, [GioiTinh] [bit] NOT NULL,
[DienThoai] [nvarchar](50) NOT NULL, [Email] [nvarchar](50) NOT NULL, [GhiChu] [nvarchar](max) NULL, [MaNV] [nvarchar](50) NOT NULL, [NgayDK] [date] NOT NULL,
CONSTRAINT [PK_NguoiHoc] PRIMARY KEY CLUSTERED
(
[MaNH] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
CÂU LỆNH SQL CƠ BẢN
INSERT INTO Nguoihoc (MaNH,HoTen, NgaySinh, GioiTinh, DienThoai, Email, GhiChu,
MaNV, NgayDK) VALUES (?, ?, ?, ?,?,?)
UPDATE Nguoihoc SET MaNH = ?, HoTen = ?, NgaySinh = ? , GioiTinh = ? , DienThoai = ?WHERE MaNH = ?,
DELETE FROM ChuyenDe WHERE MaCD = ? SELECT * FROM ChuyenDe WHERE MaCD = ?
4.2.2.4 Bảng KhoaHoc CẤU TRÚC BẢNG
TÊN CỘT KIỂU DỮ LIỆU
MaKH Int MaCD Nchar(5) HocPhi Float ThoiLuong Int NgayKG Date GhiChu Nvarchar(255) MaNV Nvarchar(20) NgayTao Date MÃ LỆNH TẠO BẢNG
CREATE TABLE [dbo].[KhoaHoc](
[MaKH] [int] IDENTITY(1,1) NOT NULL, [MaCD] [nchar](5) NOT NULL,
[HocPhi] [float] NOT NULL, [ThoiLuong] [int] NOT NULL, [NgayKG] [date] NOT NULL, [GhiChu] [nvarchar](50) NULL, [MaNV] [nvarchar](50) NOT NULL, [NgayTao] [date] NOT NULL,
CONSTRAINT [PK_KhoaHoc] PRIMARY KEY CLUSTERED
(
[MaKH] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
CÂU LỆNH SQL CƠ BẢN 4.2.2.5 Bảng HocVien CẤU TRÚC BẢNG
TÊN CỘT KIỂU DỮ LIỆU
MaHV Int
MaKH Int
MaNH Nchar(7)
Diem Float
MÃ LỆNH TẠO BẢNG
CREATE TABLE [dbo].[HocVien](
[MaHV] [int] IDENTITY(1,1) NOT NULL, [MaKH] [int] NOT NULL,
[MaNH] [nchar](7) NOT NULL, [Diem] [float] NOT NULL,
CONSTRAINT [PK_HocVien] PRIMARY KEY CLUSTERED
(
[MaHV] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
CÂU LỆNH SQL CƠ BẢN
4.2.3 THỦ TỤC LƯU
Mỗi thủ tục lưu cần làm rõ các vấn đề sau đây: o Mơ tả, mục đích sử dụng
o Tham số vào
o Kết quả ra
4.2.3.1 Sp_BangDiem()
MÃ NGUỒN CREATE PROC sp_BangDiem(@MaKH INT) AS BEGIN SELECT nh.MaNH, nh.HoTen, hv.Diem FROM HocVien hv
JOIN NguoiHoc nh ON nh.MaNH=hv.MaNH
WHERE hv.MaKH = @MaKH ORDER BY hv.Diem DESC
MÔ TẢ THAM SỐ KẾT QUẢ 4.2.3.2 Sp_DoanhThu() MÃ NGUỒN MÔ TẢ THAM SỐ KẾT QUẢ 4.2.3.3 Sp_LuongNguoiHoc() MÃ NGUỒN MÔ TẢ THAM SỐ KẾT QUẢ 4.2.3.4 Sp_DiemChuyenDe() MÃ NGUỒN MÔ TẢ THAM SỐ KẾT QUẢ 4.3 LẬP TRÌNH CSDL 4.3.1 MƠ HÌNH TỔ CHỨC LẬP TRÌNH CSDL Hình và mơ tả (DAO+JdbcHelper+Entity+CSDL) 4.3.2 JDBCHELPER (XJDBC) Mô tả lớp XJdbc
Hướng dẫn sử dụng các phương thức tiện ích của XJdbc
MƠ TẢ:
XJdbc là lớp tiện ích hỗ trợ lập trình JDBC. Lớp này gồm 3 phương thức được mô tả trong phần hướng dẫn sử dụng sau đây.
HƯỚNG DẪN SỬ DỤNG:
XJdbc.query(String sql, Object…args): ResultSet o Truy vấn dữ liệu từ CSDL
o Tham số sql: câu lệnh SELECT truy vấn có chứa ?
o Tham số: args là các giá trị cung cấp cho các dấu ? của SQL o Kết quả: ResultSet
XJdbc.update(String sql, Object…args): int
o Thao tác CSDL (INSERT, UPDATE, DELETE)
o Tham số sql: câu lệnh INSERT, UPDATE, DELETE có chứa ? o Tham số: args là các giá trị cung cấp cho các dấu ? của SQL o Kết quả: số bản ghi có ảnh hưởng
XJdbc.value(String sql, Object…args): Object o Truy vấn một giá trị từ CSDL
o Tham số sql: câu lệnh SELECT truy vấn có chứa ?
o Tham số: args là các giá trị cung cấp cho các dấu ? của SQL o Kết quả: đối tượng chứa giá trị truy vấn