Bài giảng Table

• Miền giá trị tuyết đối từ 2.23E- 308đến 1.79E +308 • n là số bít dùng lưu phần định trị, có giá trị từ 1 – 53, mặcđịnh là 53. • Sốbyte lưu trữ phụ thuộc vào giá trị của n. – Với n  [1, 24]: 4 byte, với độ chính xác là 7 chữ số thập phân. – Với n  [25, 53]: 8 byte, với độ chính xác là 15 chữ số thập phân. b) Real : 4 byte, Miền giá trị tuyệt đối 1.18E- 38đến 3.40E +38. SQL Server 6

pdf13 trang | Chia sẻ: vietpd | Lượt xem: 2076 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Bài giảng Table, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
1Chương 3: TABLE Giáo viên: Tạ Thúc Nhu Khoa CNTT trường ĐH Lạc Hồng HỆ QUẢN TRỊ CSDL SQL SERVER SQL Server2 NỘI DUNG I. Các kiểu dữ liệu II. Các phép toán III. Tạo Table trong một CSDL IV. Thay đổi cấu trúc và ràng buộc V. Xóa Table VI. Đổi tên Table VII.Mô hình quan hệ dữ liệu SQL Server3 I- CÁC KiỂU DỮ LiỆU 1. Exact Numerics: Số Chính Xác 2. Approximate Numerics: Số gần đúng 3. Date and Time - Ngày giờ 4. Character strings - Chuỗi ký tự ASCII 5. Unicode character strings - Chuổi ký tự Unicode 6. Binary Strings - Chuỗi số nhị phân 7. Other Data Types SQL Server4 1- Số Chính Xác - Exact Numerics • Bigint (8 bytes) giá trị từ - 263 đến 263-1 • Int :(4 bytes) giá trị từ - 231 đến 231 - 1. • SmallInt : (2 bytes) giá trị từ - 215 đến 215 - 1. • Tinyint : (1 byte) giá trị từ 0 đến 255. • Bit : có giá trị 0, 1 hoặc NULL. • Decimal [ ( p [, s ]) ] – P (precision) có giá trị từ 1 đến 38, là tổng số chữ số tối đa bên phải và bên trái dấu chấm thập phân. Mặc định là 18. – S (Scale) có giá trị từ 0 đến P, là số chữ số lẻ bên phải dấu chấm thập phân. Mặc định bằng 0 • Numeric [ ( p [, s ] ) ]: tương tự Decimal • Money :-922,337,203,685,477.5808 đến 922,337,203,685,477.5807 • SmallMoney : -214,748.3648 đến 214,748.3647 2SQL Server5 2- Số gần đúng - Approximate Numerics a) Float [( n )] : • Miền giá trị tuyết đối từ 2.23E- 308 đến 1.79E +308 • n là số bít dùng lưu phần định trị, có giá trị từ 1 – 53, mặc định là 53. • Số byte lưu trữ phụ thuộc vào giá trị của n. – Với n  [1, 24]: 4 byte, với độ chính xác là 7 chữ số thập phân. – Với n  [25, 53]: 8 byte, với độ chính xác là 15 chữ số thập phân. b) Real : 4 byte, Miền giá trị tuyệt đối 1.18E- 38 đến 3.40E +38. SQL Server6 3- Ngày giờ - Date And Time a) DateTime : • Miền giá trị : từ 1-1- 1753 đến 31-12- 9999 b) SmallDateTime : • Miền giá trị: 1-1- 1900 đến 6-6- 2079 Chú ý: Hằng ngày giờ bao trong dấu nháy đơn Ví dụ: ‘1998-01-20 23:59:59.997’ SQL Server7 4- Chuỗi ký tự - Character Strings • Char [(n)] : độ dài cố định, tối đa là 8000 byte. • Varchar [( n )]: độ dài không cố định, tối đa là 8000 byte. • Varchar( max ) | Text: độ dài không cố định, tối đa là 231-1 byte. SQL Server8 5- Chuổi ký tự Unicode - Unicode Character Strings • nChar [( n )] : độ dài cố định, tối đa là 4000 ký tự. • nVarchar[( n )] : độ dài không cố định, tối đa là 4000 ký tự. • nVarchar(max) | nText : độ dài không cố định, tối đa là 2^31–1 byte. Chú ý: Hằng chuỗi Unicode bao trong dấu nháy đơn và phải bắt đầu bằng chữ N: N’sssss’ 3SQL Server9 6- Dữ liệu nhị phân - Binary Strings • Binary [( n )] : độ dài cố định, n có tối đa 8000 bytes. • Varbinary [( n )] : độ dài thay đổi, n có tối đa 8000 bytes. • Varbinary( max ) | Image : độ dài thay đổi, lưu trong 2^31 – 1 bytes. SQL Server10 7- Other Data Types • Sql_Variant : dùng lưu giá trị của các kiểu dữ liệu khác trong SQL Server ngoại trừ các kiểu text, ntext, Image, timestamp, và sql_variant. • Timestamp : kiểu số (binary(8) hay varbinary(8)). Cột khai báo kiểu này sẽ được tự động cập nhật với giá trị phân biệt mỗi khi thêm mẫu tin mới.. • UniqueIdentifier : 16 bytes GUID (Globally Unique Identifier). Nhận giá trị này bằng hàm NewID(). • XML : dùng lưu dữ liệu XML SQL Server11 II- CÁC PHÉP TOÁN 1. Các phép toán số học: * (nhân), / (chia nguyên hay thực), % (phần dư); + (cộng), - (trừ) 2. Phép nối chuỗi : + 3. Các phép toán so sánh: , >=, !>, =, hay != 4. Các phép toán lôgic: NOT, AND (conjunction), OR (disjunction). SQL Server12 II- Các phép toán (tt) 5. Các phép toán phạm vi: a) IS [NOT] NULL b) [NOT] IN () c) [NOT] BETWEEN AND d) [NOT] LIKE ‘Mẫu v.bản’ Ký tự đơn bất kỳ không nằm trong giới hạn được chỉ định ví dụ [^a-f] hay một tập [^abcdef] [^…] Ký tự đơn bất kỳ trong giới hạn được chỉ định ví dụ [a-f] hay một tập [abcdef] [ … ] Ký tự đơn bất kỳ_ Chuỗi ký tự bất kỳ gồm không hoặc nhiều ký tự% Ý nghĩa đại diệnKý tự 4SQL Server13 III- TẠO TABLE 1. Bằng Lệnh CREATE TABLE 2. Sử dụng Object Explorer - Khai báo các cột - Khai báo ràng buộc dữ liệu SQL Server14 1- Bằng Lệnh CREATE TABLE: Cú pháp : CREATE TABLE TableName ( column_name data_type [] | computer_column_name AS [PERSISTED] | [ , ...n] ) [ON { file_group | PRIMARY } ] SQL Server15 1.1 Khai báo cột dữ liệu • CREATE TABLE SanPham ( MaSP Smallint , TenSP varchar(30) , DonGia Money , SoTon Real ) • CREATE TABLE DDH ( MaDH Int , MaNCC Int , NgayLap DateTime , NgayYCGiao DateTime ) SQL Server16 1.2 Khai báo cột biểu thức computer_column_name AS expression [PERSISTED] • Cột tính toán, là cột chỉ đọc, chứa dữ liệu tính toán từ những cột khác. Mặc định không lưu giá trị cột tính toán trong table. CREATE TABLE CTDH ( MaDH Int , MaSP SmallInt , SL float , DGBan Money , ThanhTien As SL * DGBan ) • Dùng PERSISTED để chỉ định lưu giá trị cột tính toán trong table và tự động cập nhật giá trị. Cột tính toán PERSISTED có thể được tham gia vào khóa của bảng. CREATE TABLE mytable ( Low int, High int, myavg AS (low + high)/2 PERSISTED ) 5SQL Server17 1.3 Khai báo ràng buộc dữ liệu (Constraint) Có 2 cách khai báo ràng buộc trên table phụ thuộc vào số cột tham gia điều kiện của ràng buộc: a) Ràng buộc dữ liệu trên một cột (Column Constraint) b) Ràng buộc dữ liệu trên nhiều cột của Table (Table Constraint) SQL Server18 Được viết ngay sau lời khai báo cột dữ liệu Cú pháp: [CONSTRAINT constraint_name ] NULL | NOT NULL | PRIMARY KEY | UNIQUE | REFERENCES ref_table [(ref_column)] [ON DELETE {CASCADE | NO ACTION | SET NULL | SET DEFAULT } ] [ON UPDATE {CASCADE | NO ACTION | SET NULL | SET DEFAULT } ] | CHECK (logical_expression) | DEFAULT a) Các loại ràng buộc trên một cột SQL Server19 Ví dụ: Khai báo ràng buộc trên 1 cột CREATE TABLE SanPham ( MaSP Smallint Primary Key , TenSP varchar(30) Not Null Unique, DonGia Money Default 0 Check (DonGia >=0), SoTon Real Default 0 Check (SoTon >=0), MaLoaiSP Smallint Not Null References LoaiSP(MaLoaiSP) On Delete No Action On Update Cascade ) SQL Server20 Ví dụ: Đặt tên ràng buộc trên một cột CREATE TABLE SanPham ( MaSP SmallInt Constraint pkMaSP Primary Key , TenSP varchar(30) Constraint uniTenSP Unique , DonGia Money Constraint chkDonGia Check (DonGia >=0) , SoTon Real Constraint dfSoTon Default 0 , MaLoaiSP SmallInt Constraint nnMaLoaiSP Not Null Constraint fkMaLSP References LoaiSP (MaLoaiSP) On Delete No Action On Update Cascade ) 6SQL Server21 b- Các loại ràng buộc trên nhiều cột [CONSTRAINT constraint_name ] PRIMARY KEY ( têncột [ ASC | DESC ] [ ,...n ] ) | UNIQUE ( têncột [ ASC | DESC ] [ ,...n ] ) | FOREIGN KEY ( têncột [,...] ) REFERENCES ref_table [( )] [ ON DELETE { CASCADE | NO ACTION | SET NULL | SET DEFAULT } ] [ ON UPDATE { CASCADE | NO ACTION | SET NULL | SET DEFAULT} ] | CHECK ( logical_expression ) Được viết thành một mệnh đề riêng biệt Cú pháp SQL Server22 Ví dụ - Khai báo khóa chính gồm nhiều cột CREATE TABLE CTDH ( MaDH Int Not Null Reference DDH, MaSP SmallInt Not Null Reference SanPham, SoLuong float Default 0 Check (SoLuong > 0), DGBan Money Default 0 Check (DonGia > 0), ThanhTien As SL * DGBan, Constraint pk_CTHD Primary Key (MaDH, MaSP) ) SQL Server23 Ví dụ - Khai báo ràng buộc liên thuộc tính CREATE TABLE DDH ( MADH SmallInt Constraint pkDDH Primary Key , NgayDH DateTime Default GetDate( ) Not Null , NgayYCGiao DateTime DEFAULT GetDate( ) Not Null , Constraint chkNgayYCGiao Check (NgayDH <= NgayYCGiao) , MaNCC SmallInt Not Null Constraint fk_DHH_NCC References NHACC(MaNCC) ) SQL Server24 1.4- Khai báo cột tự động điền giá trị phân biệt Có các cách sau: • Dùng kiểu Timestamp • Dùng thuộc tính IDENTITY [(seed, increment )] : điền tự động một số nguyên cho mẫu tin mới. Người dùng không thể nhập dữ liệu cho cột có thuộc tính này. Mỗi table chỉ có một cột khai báo thuộc tính Identity. • Dùng kiểu UniqueIdentifier với chỉ định giá trị Default từ hàm NEWID() hay hàm NEWSEQUENTIALID() để nhận giá trị phân biệt toàn cầu. 7SQL Server25 Ví dụ: Tạo cột có giá trị phân biệt CREATE TABLE NhaCungCap ( MaNCC int IDENTITY(1, 1) PRIMARY KEY, TenNCC char(30) NOT NULL ) CREATE TABLE KhachHang ( MaKH uniqueidentifier DEFAULT NEWID() PRIMARY KEY, TenKH char(30) NOT NULL ) SQL Server26 1.5- Tạo Table tạm • Table tạm lưu trữ bên trong CSDL TempDB • Table tạm cục bộ được khai báo với 1 dấu #, chỉ được truy xuất bởi kết nối vừa tạo ra nó. • Table tạm toàn cục được khai báo với 2 dấu #, được truy xuất bởi các kết nối hiện hành CREATE TABLE #BangTam ( Cot1 int PRIMARY KEY, Cot2 char(10) NOT NULL, Cot3 Datetime ) SQL Server27 2- Sử dụng Object Explorer • Click phải mục Tables trong CSDL và chọn New Table… SQL Server28 • Lần lượt khái báo các cột. Với mỗi cột, nhập tên cột, chọn kiểu dữ liệu và chỉ định các thuộc tính cần thiết. • Click nút Save, đặt tên table và click nút OK 8SQL Server29 IV- THAY ĐỔI CẤU TRÚC - RÀNG BUỘC • Hiệu chỉnh, thêm, xóa cột và ràng buột • Kiểm tra hay ngưng kiểm tra ràng buộc 1. Bằng Lệnh ALTER TABLE 2. Sử dụng Object Explorer SQL Server30 1- Sử dụng lệnh ALTER TABLE Cú pháp chung: ALTER TABLE table_name ALTER COLUMN col_name data_type[(p [, s])] [NULL | NOT NULL ] | ADD | DROP CONSTRAINT constraint_name | DROP COLUMN col_name [,...n] | {CHECK | NOCHECK} CONSTRAINT { ALL | constraint_name[,...n] } SQL Server31 1.1- Đổi kiểu dữ liệu hoặc kích thước của cột ALTER TABLE table_name ALTER COLUMN col_name data_type [ NULL | NOT NULL] Ví dụ:ALTER TABLE KhachHang ALTER COLUMN TenKH CHAR (40) NULL Chú ý: Không thể Giảm kích thước của cột nhỏ hơn kích thước dữ liệu hiện có Thay đổi kiểu dữ liệu của cột khi cột đó đã có dữ liệu hoặc có ràng buộc. Thay đổi kiểu của cột đã dùng trong cột tính toán Từ NULL thành NOT NULL SQL Server32 1.2- Thêm cột mới ALTER TABLE ADD [,...] CREATE TABLE NhanVien ( MaNV Int CONSTRAINT pk_NV Primary Key, TenNV VarChar(40) NOT NULL) GO ALTER TABLE NhanVien ADD NoiSinh Varchar(20) DEFAULT ‘Đồng Nai’, MaNVQL Int NULL Constraint fk_MaNV References NhanVien(MaNV) 9SQL Server33 Chú ý khi thêm cột NOT NULL Trong trường hợp Table đã có dữ liệu, nếu bạn cần thêm cột với ràng buộc NOT NULL thì có thể thực hiện một trong 2 cách sau: • Cách 1: thực hiện qua 3 bước: (i) thêm cột với thuộc tính NULL, (ii) Điền đầy đủ các giá trị cho cột, (iii) Đổi lại thuộc tính của cột thành NOT NULL. • Cách 2: Thêm cột mới có ràng buộc Default và thuộc tính WITH VALUES để điền tự động giá trị cho các dòng đang tồn tại trong bảng. ALTER TABLE SanPham ADD SoTon Float NOT NULL CONSTRAINT df_ST DEFAULT 0 WITH VALUES SQL Server34 3- Xóa cột : ALTER TABLE DROP COLUMN ColName [,...n] Ví dụ: ALTER TABLE SanPham DROP COLUMN SoTon Chú ý: Không thể xóa những cột có ràng buộc CHECK, DEFAULT, FOREIGN KEY, UNIQUE, PRIMARY KEY SQL Server35 4- Thêm RBTV cho bảng ALTER TABLE table_name [WITH CHECK | WITH NOCHECK] ADD [,...n] •WITH NOCHECK: Không kiểm tra ràng buộc đối với dữ liệu đã nhập •Table_constraint = PRIMARY KEY( column_name [ , ...n ] ) | UNIQUE (column_name [ , ...n ] ) | FOREIGN KEY (column_name [ , ...n ] ) REFERENCES ref_table ( ref_col [ ,...n ] ) [ON DELETE {CASCADE | NO ACTION | SET NULL | SET DEFAULT} ] [ON UPDATE {CASCADE | NO ACTION | SET NULL | SET DEFAULT} ] | DEFAULT FOR column_name [ WITH VALUES ] | CHECK( BT Điều kiện ) SQL Server36 Ví dụ: CREATE TABLE DDH ( MADH SmallInt Not Null, MaNCC SmallInt, NgayDH DateTime, NgayYCGiao DateTime ) Go ALTER TABLE DDH ADD Constraint pk_DDH Primary Key(MaDH) , Constraint df_NgayDH Default GetDate( ) For NgayDH , Constraint chk_NgayYCGiao Check (NgayDH <= NgayYCGiao) , Constraint fk_DDH_NhaCC Foreign Key(MaNCC) References NHACC 10 SQL Server37 5- Hủy bỏ RBTV khỏi bảng: ALTER TABLE table_name DROP CONSTRAINT Ví dụ: ALTER TABLE SanPham DROP CONSTRAINT df_SoTon SQL Server38 6- Kích hoạt hay tạm ngưng kiểm tra ràng buộc Foreign key và Check ALTER TABLE table_name {CHECK | NOCHECK} CONSTRAINT {ALL | tênRB [,...n]} Ví dụ : -- Tạm ngưng kiểm tra ràng buộc. ALTER TABLE SanPham NOCHECK CONSTRAINT chk_DonGia -- Kích hoạt kiểm tra constraint. ALTER TABLE SanPham CHECK CONSTRAINT chk_DonGia SQL Server39 7- Đổi tên cột : SP_RENAME 'TableName.OldName', 'NewName', 'COLUMN' Ví dụ: SP_RENAME ‘SanPham.DonGia', ‘DonGiaSP', 'COLUMN' SQL Server40 2- Sử dụng Object Explorer • Click phải vào tên bảng và chọn Modify Table… 11 SQL Server41 V- XEM THÔNG TIN TABLE: 1. Table Sys.Objects chứa danh sách các table, view và các ràng buộc trên các table trong CSDL hiện hành. – Thuộc tính Name chứa tên đối tượng – Thuộc tính Object_ID chứa giá trị nhận diện đối tượng. Có thể dùng thủ tục Object_ID('TênĐốitượng') để trả về giá trị Object_ID của đối tượng – Thuộc tính Type chứa mã loại đối tượng: U - User's table, S - System table; V - View; Tr - Trigger, D - Default, C - Check, F - Foreign Key, PK – Primary Key, Uq - Unique Key , P – Procedure, Fn – Function • Bạn có thể liệt kê danh sách các table đã tạo bằng lệnh: Select * From Sys.Objects Where Type = 'U‘ SQL Server42 IV- XEM THÔNG TIN TABLE: 2. Table Sys.Columns chứa danh sách các cột trong các table hay view; các tham số trong các thủ tục hay hàm của CSDL hiện hành – Thuộc tính Name chứa tên cột hay tên tham số. – Thuộc tính Object_ID chứa định danh đối tượng Table, View, thủ tục hay hàm. Dùng thủ tục Object_ID('object_name') để trả về giá trị Object_ID của các đối tượng này Ví dụ: Liệt kê thông tin các cột trong table 'HoaDon' Select * From sys.Columns Where Object_ID= Object_ID('HoaDon') SQL Server43 3- Sử dụng Hàm hoặc thủ tục: • SP_HELP [ ‘Tên’ ] : Xem thông tin các đối tượng trong CSDL, các kiểu dữ liệu. • Hàm Object_ID('TênĐốitượng'): trả về giá trị ID của đối tượng trong table SysObjects • Hàm ObjectProperty( Object_ID, 'IsUserTable'): trả về giá trị 1 nếu Object_ID là của table ngược lại bằng 0. Ví dụ: Liệt kê danh sách các Table đã tạo Select * From Sys.Objects Where ObjectProperty(Object_ID, 'IsUserTable’ ) = 1 • Hàm @@IDENTITY dùng nhận giá trị identity của mẫu tin được chèn cuối cùng. SQL Server44 V- XÓA TABLE : DROP TABLE [, …n] Chú ý: Không thể xóa Table cha được tham chiếu bởi Table khác. 12 SQL Server45 VI- ĐỔI TÊN BẢNG: EXEC SP_RENAME 'OldName', 'NewName' Ví dụ: Đổi tên table NCC thành NhaCungCap. EXEC sp_rename ‘NCC', ‘NhaCungCap' SQL Server46 VII- MÔ HÌNH QUAN HỆ • Biểu diễn mối quan hệ dữ liệu giữa các bảng • Khai báo, hiệu chỉnh các ràng buộc khóa ngoại • Tạo, sửa và xóa cấu trúc bảng SQL Server47 1- Tạo mới mô hình quan hệ B1: Click phải vào Database Diagram và chọn New Database Diagram B2: Chọn bảng cho mô hình B3: Click nút Close kết thúc quá trình tạo mô hình SQL Server48 L o a i H a n g M a LH T e n LH M o T a H in h M a t H a n g M a M H T e n M H M a N C C M a LH D VT D o n G ia S o T o n f k _ M a t H a n g _ Lo a iH a n g K h u V u c * M a K V T e n K V M a N VQ L K h u V u c L o a i H a n g M a K V M a LH F K _ K h u V u c Lo a iH a n g _ K h u V u c 1 F K _ K h u V u c Lo a iH a n g _ Lo a iH a n g 1 N h a n V i e n * M a N V H o T e n P h a i D ia C h i D ie n T h o a i Lu o n g C B C o n g V ie c M a K V F K _ N h a n V ie n _ K h u V u c N h a C u n g C a p M a N C C T e n N C C D ia C h i D ie n T h o a i f k _ M a t H a n g _ N h a C C F K _ K h u V u c _ N h a n V ie n 13 SQL Server49 2- Menu tắt của Mô hình quan hệ: Click phải vào màn hình trống của Diagram SQL Server50 3- Menu tắt của Table: Click phải trên Table SQL Server51 Bài tập • Thực hiện bài tập trong file TheThao.DOC SQL Server52 QUẢN LÝ MUA BÁN HÀNG HÓA 1. LOAIHANG( MaLH, TenLH, MoTa) 2. MATHANG( MaMH, TenMH, MaLH, DVT, DonGia, SoTon) 3. NHANVIEN(MaNV, HoTenNV, NgaySinh, GioiTinh) 4. HOADON( SoHD, NgayHD, MaNV, TienHD) 5. CTHD(SoHD, MaMH, DGBan, SL) 6. NHACUNGCAP( MaNCC, TenNCC, DiaChi, DienThoai ) 7. CUNGUNG(MaNCC, MaMH) 8. DDH(MaDH, NgayDH, NgayYCGiao, MaNCC, TIENDH) 9. CTDH(MaDH, MaMH, SLDat, DonGiaDat) 10. GIAOHANG(MaGH , NgayGH, MaDH) 11. CTGH(MaGH, MaMH, SLGiao) 12. TONKHO(THANG, NAM, MaMH,TonDauKy,NhapTrongKy,XuatTrongKy)