intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Giáo trình Hệ quản trị cơ sở dữ liệu SQL server (Ngành: Công nghệ thông tin - Cao đẳng) - Trường Cao đẳng Xây dựng số 1

Chia sẻ: _ _ | Ngày: | Loại File: PDF | Số trang:75

7
lượt xem
4
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Giáo trình "Hệ quản trị cơ sở dữ liệu SQL server (Ngành: Công nghệ thông tin - Cao đẳng)" được biên soạn với mục tiêu nhằm giúp sinh viên nắm được các kiến thức về: Các thành phần hệ quản trị cơ sở dữ liệu, các khái niệm về cơ sở dữ liệu quan hệ hướng đối tượng và cơ sở dữ liệu quan hệ, ngôn ngữ MS SQL; các kiến trúc của hệ quản trị cơ sở dữ liệu MS SQL Server, cách làm việc và tương tác giữa các thành phần kiến trúc trong hệ thống. Mời các bạn cùng tham khảo!

Chủ đề:
Lưu

Nội dung Text: Giáo trình Hệ quản trị cơ sở dữ liệu SQL server (Ngành: Công nghệ thông tin - Cao đẳng) - Trường Cao đẳng Xây dựng số 1

  1. BỘ XÂY DỰNG TRƯỜNG CAO ĐẲNG XÂY DỰNG SỐ 1 GIÁO TRÌNH MÔN HỌC: HỆ QUẢN TRỊ CƠ SỞ DỮ LIỆU SQL SERVER NGÀNH: CÔNG NGHỆ THÔNG TIN TRÌNH ĐỘ: CAO ĐẲNG Ban hành kèm theo Quyết định số: 368ĐT/QĐ-CĐXD1 ngày 10 tháng 8 năm 2021 của Hiệu trưởng Trường Cao đẳng Xây dựng số 1 Hà Nội, năm
  2. TUYÊN BỐ BẢN QUYỀN Tài liệu này thuộc loại sách giáo trình nên các nguồn thông tin có thể được phép dùng nguyên bản hoặc trích dùng cho các mục đích về đào tạo và tham khảo. Mọi mục đích khác mang tính lệch lạc hoặc sử dụng với mục đích kinh doanh thiếu lành mạnh sẽ bị nghiêm cấm. 1
  3. LỜI NÓI ĐẦU Giáo trình hệ quản trị cơ sở dữ liệu sql server được biên soạn nhằm phục vụ cho giảng dạy và học tập cho trình độ Cao đẳng ngành công nghệ thông tin ở trường Cao đẳng Xây dựng số 1. HỆ QUẢN TRỊ CƠ SỞ DỮ LIỆU SQL SERVER là môn học cơ sở ngành nhằm cung cấp các kiến thức về những kiến thức cơ bản về cơ sở dữ liệu, tạo và quản lý cơ sở dữ liệu trên phần mềm SQL Giáo trình HỆ QUẢN TRỊ CƠ SỞ DỮ LIỆU SQL SERVER do bộ môn Tin cơ sở do Ths. Lê Thị Lương làm chủ biên. Giáo trình này được viết theo đề cương môn học Cơ sở dữ liệu. Ngoài ra giáo trình còn bổ sung thêm một số kiến thức mà trong các giáo trình trước chưa đề cập tới. Nội dung gồm 04 chương Chương 1: Tổng quan về SQL Chương 2: Ngôn ngữ định nghĩa dữ liệu Chương 3: Ngôn ngữ thao tác dữ liệu Chương 4: Thiết kế View Trong quá trình biên soạn, nhóm giảng viên Bộ môn Tin học cơ sở của Trường Cao đẳng Xây dựng Số 1 - Bộ Xây dựng, đã được sự động viên quan tâm và góp ý của các đồng chí lãnh đạo, các đồng nghiệp trong và ngoài trường. Mặc dù có nhiều cố gắng, nhưng trong quá trình biên soạn, biên tập và in ấn khó tránh khỏi những thiếu sót. Chúng tôi xin được lượng thứ và tiếp thu những ý kiến đóng góp. Trân trọng cảm ơn! Hà Nội, ngày……tháng……năm……… Chủ biên Ths. Lê Thị Lương 2
  4. MỤC LỤC CHƯƠNG 1: TỔNG QUAN VỀ SQL........................................................................................ 6 1.1 SQL là ngôn ngữ cơ sở dữ liệu quan hệ............................................................................ 7 1.2 Vai trò của SQL ................................................................................................................ 8 1.3 Tổng quan về cơ sở dữ liệu quan hệ ................................................................................. 8 1.3.1 Mô hình dữ liệu quan hệ ............................................................................................ 8 1.3.2 Bảng (Table) .............................................................................................................. 9 1.3.3 Khoá của bảng.......................................................................................................... 10 1.3.4 Mối quan hệ và khoá ngoại ...................................................................................... 10 1.4 Sơ lược về SQL ............................................................................................................... 11 1.4.1 Câu lệnh SQL........................................................................................................... 11 1.4.2 Qui tắc sử dụng tên trong SQL ............................................................................... 13 1.4.3 Kiểu dữ liệu.............................................................................................................. 13 1.4.4 Giá trị NULL............................................................................................................ 15 CHƯƠNG 2: NGÔN NGỮ ĐỊNH NGHĨA DỮ LIỆU ............................................................. 20 2.2 Tạo bảng dữ liệu ............................................................................................................. 21 2.2.1 Ràng buộc CHECK .................................................................................................. 23 2.1.2 Ràng buộc PRIMARY KEY .................................................................................... 23 2.1.3 Ràng buộc UNIQUE ................................................................................................ 24 2.1.4 Ràng buộc FOREIGN KEY ..................................................................................... 24 2.3 Xoá bảng ......................................................................................................................... 26 2.4. Cập nhật, bổ sung và xoá dữ liệu ................................................................................... 27 2.4.1 Cập nhật, bổ sung dữ liệu ....................................................................................... 28 2.4.2 Xoá dữ liệu ............................................................................................................... 30 CHƯƠNG 3: NGÔN NGỮ THAO TÁC DỮ LIỆU ................................................................ 35 3.1 Truy xuất dữ liệu với câu lệnh SELECT .................................................................... 35 3.1.1 Mệnh đề FROM ....................................................................................................... 36 3.1.2 Danh sách chọn trong câu lệnh SELECT ................................................................ 37 3.1.3 Chỉ định điều kiện truy vấn dữ liệu ......................................................................... 39 3.1.4 Tạo mới bảng dữ liệu từ kết quả của câu lệnh SELECT ......................................... 43 3.1.5 Sắp xếp kết quả truy vấn .......................................................................................... 43 CHƯƠNG 4: THIẾT KẾ VIEW ............................................................................................... 50 3
  5. 4.1 Khái niệm cơ bản về ràng buộc ...................................................................................... 50 4.2 Ràng buộc dữ liệu nhập vào............................................................................................ 50 4.3 Ràng buộc miền .............................................................................................................. 51 4.4 Ràng buộc trọn vẹn ......................................................................................................... 51 4.5 Bảng ảo (view) ................................................................................................................ 52 4.5.1. Khái niệm về view .................................................................................................. 52 4.5.2. Cách dùng view để lọc dữ liệu ................................................................................ 53 4.5.3. Cách cập nhật dữ liệu vào view .............................................................................. 54 4.6 Sao lưu và phục hồi dữ liệu ............................................................................................ 56 4.7. Backup ........................................................................................................................... 56 4.7.1 Backup trong SQL ................................................................................................... 56 4.7.2 Các bước Backup trong SQL ................................................................................... 57 4.8. Restore ........................................................................................................................... 59 4.8.1 Restore trong SQL ................................................................................................... 59 4.8.2 Các bước Restore trong SQL ................................................................................... 60 4
  6. Tên môn học: HỆ QUẢN TRỊ CƠ SỞ DỮ LIỆU SQL SERVER Mã số môn học: MH19 Thời gian thực hiện môn học: 75 giờ; (Lý thuyết: 15 giờ; Thực hành, thí nghiệm, thảo luận, bài tập: 56 giờ; Kiểm tra: 4 giờ) I. Vị trí, tính chất của môn học: - Vị trí: là môn học bắt buộc thuộc nhóm các môn học, mô đun chuyên ngành trong chương trình Quản trị mạng - Tính chất: là môn học chuyên môn nghề. Đây là môn học cơ sở ngành của ngành quản trị mạng, cung cấp cho các kiến thức cơ bản về truy vấn dữ liệu. II. Mục tiêu môn học: -Về kiến thức: Mô tả các thành phần hệ quản trị cơ sở dữ liệu, các khái niệm về cơ sở dữ liệu quan hệ hướng đối tượng và cơ sở dữ liệu quan hệ, ngôn ngữ MS SQL.Trình bày các kiến trúc của hệ quản trị cơ sở dữ liệu MS SQL Server, cách làm việc và tương tác giữa các thành phần kiến trúc trong hệ thống. - Về kỹ năng: Thực hiện thành thạo các thao tác quản trị tài khoản người dùng và tài khoản nhóm đối với hệ thống MS SQL Server. Thiết lập cấu hình và giải quyết các vấn đề thường xảy ra trên mạng khi sử dụng truy cập cơ sở dữ liệu. - Về năng lực tự chủ và trách nhiệm: Rèn luyện lòng yêu nghề, tư thế tác phong công nghiệp, tính kiên trì, sáng tạo trong công việc . III. Nội dung môn học: 1. Nội dung tổng quát và phân bổ thời gian: Thời gian Thực hành, thí Số TT Tên chương mục Tổng Lý Kiểm nghiệm, thảo số thuyết tra luận, bài tập 1 Chương 1: Tổng quan về 15 2 13 SQL 2 Chương 2: Ngôn ngữ định 20 4 14 2 nghĩa dữ liệu 3 Chương 3 Ngôn ngữ thao 25 5 20 tác dữ liệu 4 Chương 4: Thiết kế View 15 4 9 2 Cộng 75 15 56 4 5
  7. CHƯƠNG 1: TỔNG QUAN VỀ SQL Mục tiêu bài học 1. Trình bày được các khái niệm trong cơ sở dữ liệu; 2. Trình bày được vai trò của SQL; 3. Trình bày được tổng quan về cơ sở dữ liệu quan hệ; 4. Trình bày được các sơ lược về SQL. 6
  8. CHƯƠNG 1: TỔNG QUAN VỀ SQL 1.1 SQL là ngôn ngữ cơ sở dữ liệu quan hệ SQL, viết tắt của Structured Query Language (ngôn ngữ hỏi có cấu trúc), là công cụ sử dụng để tổ chức, quản lý và truy xuất dữ liệu đuợc lưu trữ trong các cơ sở dữ liệu. SQL là một hệ thống ngôn ngữ bao gồm tập các câu lệnh sử dụng để tương tác với cơ sở dữ liệu quan hệ. Tên gọi ngôn ngữ hỏi có cấu trúc phần nào đã liên tưởng đến một công cụ (ngôn ngữ) dùng để truy xuất dữ liệu trong các cơ sở dữ liệu, khả năng của SQL vượt xa so với một công cụ truy xuất dữ liệu, mục đích ban đầu khi SQL được xây dựng nên và truy xuất dữ liệu là một trong những chức năng quan trọng của nó. SQL được sử dụng để điều khiển tất cả các chức năng mà một hệ quản trị cơ sở dữ liệu cung cấp cho người dùng bao gồm: • Định nghĩa dữ liệu: SQL cung cấp khả năng định nghĩa các cơ sở dữ liệu, các cấu trúc lưu trữ và tổ chức dữ liệu cũng như mối quan hệ giữa các thành phần dữ liệu. • Truy xuất và thao tác dữ liệu: Với SQL, người dùng có thể dễ dàng thực hiện các thao tác truy xuất, bổ sung, cập nhật và loại bỏ dữ liệu trong các cơ sở dữ liệu. • Điều khiển truy cập: SQL có thể được sử dụng để cấp phát và kiểm soát các thao tác của người sử dụng trên dữ liệu, đảm bảo sự an toàn cho cơ sở dữ liệu • Đảm bảo toàn vẹn dữ liệu: SQL định nghĩa các ràng buộc toàn vẹn trong cơ sở dữ liệu nhờ đó đảm bảo tính hợp lệ và chính xác của dữ liệu trước các thao tác cập nhật cũng như các lỗi của hệ thống. Như vậy, có thể nói rằng SQL là một ngôn ngữ hoàn thiện được sử dụng trong các hệ thống cơ sở dữ liệu và là một thành phần không thể thiếu trong các hệ quản trị cơ sở dữ liệu. Mặc dù SQL không phải là một ngôn ngữ lập trình như C, C++, Java song các câu lệnh mà SQL cung cấp có thể được nhúng vào trong các ngôn ngữ lập trình nhằm xây dựng các ứng dụng tương tác với cơ sở dữ liệu. Khác với các ngôn ngữ lập trình quen thuộc như C, C++, Java. SQL là ngôn ngữ có tính khai báo. Với SQL, người dùng chỉ cần mô tả các yêu cầu cần phải thực hiện trên cơ sở dữ liệu mà không cần phải chỉ ra cách thức thực hiện các yêu cầu như thế nào. Chính vì vậy, SQL là ngôn ngữ dễ tiếp cận và dễ sử dụng. 7
  9. 1.2 Vai trò của SQL Trong hầu hết các hệ quản trị cơ sở dữ liệu quan hệ, SQL có những vai trò như sau: • SQL là ngôn ngữ hỏi có tính tương tác: Người sử dụng có thể dễ dàng thông qua các trình tiện ích để gởi các yêu cầu dưới dạng các câu lệnh SQL đến cơ sở dữ liệu và nhận kết quả trả về từ cơ sở dữ liệu • SQL là ngôn ngữ lập trình cơ sở dữ liệu: Các lập trình viên có thể nhúng các câu lệnh SQL vào trong các ngôn ngữ lập trình để xây dựng nên các chương trình ứng dụng giao tiếp với cơ sở dữ liệu • SQL là ngôn ngữ quản trị cơ sở dữ liệu: Thông qua SQL, người quản trị cơ sở dữ liệu có thể quản lý được cơ sở dữ liệu, định nghĩa các cấu trúc lưu trữ dữ liệu, điều khiển truy cập cơ sở dữ liệu. • SQL là ngôn ngữ cho các hệ thống khách/chủ (client/server): Trong các hệ thống cơ sở dữ liệu khách/chủ, SQL được sử dụng như là công cụ để giao tiếp giữa các trình ứng dụng phía máy khách với máy chủ cơ sở dữ liệu. • SQL là ngôn ngữ truy cập dữ liệu trên Internet: Cho đến nay, hầu hết các máy chủ Web cũng như các máy chủ trên Internet sử dụng SQL với vai trò là ngôn ngữ để tương tác với dữ liệu trong các cơ sở dữ liệu. • SQL là ngôn ngữ cơ sở dữ liệu phân tán: Đối với các hệ quản trị cơ sở dữ liệu phân tán, mỗi một hệ thống sử dụng SQL để giao tiếp với các hệ thống khác trên mạng, gởi và nhận các yêu cầu truy xuất dữ liệu với nhau. • SQL là ngôn ngữ sử dụng cho các cổng giao tiếp cơ sở dữ liệu: Trong một hệ thống mạng máy tính với nhiều hệ quản trị cơ sở dữ liệu khác nhau, SQL thường được sử dụng như là một chuẩn ngôn ngữ để giao tiếp giữa các hệ quản trị cơ sở dữ liệu. 1.3 Tổng quan về cơ sở dữ liệu quan hệ 1.3.1 Mô hình dữ liệu quan hệ Mô hình dữ liệu quan hệ được Codd đề xuất năm 1970 và đến nay trở thành mô hình được sử dụng phổ biến trong các hệ quản trị cơ sở dữ liệu thương mại. Nói một cách đơn giản, một cơ sở dữ 8
  10. liệu quan hệ là một cơ sở dữ liệu trong đó tất cả dữ liệu được tổ chức trong các bảng có mối quan hệ với nhau. Mỗi một bảng bao gồm các dòng và các cột: mỗi một dòng được gọi là một bản ghi (bộ) và mỗi một cột là một trường (thuộc tính). - Ví dụ: Bảng CBQL - Ví dụ 2: Bảng GVCN - Ví dụ 3: Bảng CVHT 1.3.2 Bảng (Table) Trong cơ sở dữ liệu quan hệ, bảng là đối tượng được sử dụng để tổ chức và lưu trữ dữ liệu. Một cơ sở dữ liệu bao gồm nhiều bảng và mỗi bảng được xác định duy nhất bởi tên bảng. Một bảng bao gồm một tập các dòng và các cột: mỗi một dòng trong bảng biểu diễn cho một thực thể (mỗi một dòng trong bảng HOCVIEN tương ứng với một Học viên); và mỗi một cột biểu diễn cho một tính chất của thực thể (chẳng hạn cột NGAYSINH trong bảng HOCVIEN biểu diễn cho ngày sinh của các học viên được lưu trữ trong bảng). 9
  11. Như vậy, liên quan đến mỗi một bảng bao gồm các yếu tố sau: • Tên của bảng: được sử dụng để xác định duy nhất mỗi bảng trong cơ sở dữ liệu. • Cấu trúc của bảng: Tập các cột trong bảng. Mỗi một cột trong bảng được xác định bởi một tên cột và phải có một kiểu dữ liệu nào đó (chẳng hạn cột NGAYSINH trong bảng HOCVIEN có kiểu là SMALLTIME). Kiểu dữ liệu của mỗi cột qui định giá trị dữ liệu có thể được chấp nhận trên cột đó. • Dữ liệu của bảng: Tập các dòng (bản ghi) hiện có trong bảng. 1.3.3 Khoá của bảng Trong một cơ sở dữ liệu được thiết kế tốt, mỗi một bảng phải có một hoặc một tập các cột mà giá trị dữ liệu của nó xác định duy nhất một dòng trong một tập các dòng của bảng. Tập một hoặc nhiều cột có tính chất này được gọi là khoá của bảng. Việc chọn khoá của bảng có vai trò quan trọng trong việc thiết kế và cài đặt các cơ sở dữ liệu quan hệ. Các dòng dữ liệu trong một bảng phải có giá trị khác nhau trên khoá. Bảng MONHOC trong hình dưới đây có khoá là cột MAMH Một bảng có thể có nhiều tập các cột khác nhau có tính chất của khoá (tức là giá trị của nó xác định duy nhất một dòng dữ liệu trong bảng). Trong trường hợp này, khoá được chọn cho bảng được gọi là khoá chính (primary key) và những khoá còn lại được gọi là khoá phụ hay là khoá dự tuyển (candidate key/unique key). 1.3.4 Mối quan hệ và khoá ngoại Các bảng trong một cơ sở dữ liệu không tồn tại độc lập mà có mối quan hệ mật thiết với nhau về mặt dữ liệu. Mối quan hệ này được thể hiện thông qua ràng buộc giá trị dữ liệu xuất hiện ở bảng này phải có xuất hiện trước trong một bảng khác. Mối quan hệ giữa các bảng trong cơ sở dữ liệu nhằm đàm bảo được tính đúng đắn và hợp lệ của dữ liệu trong cơ sở dữ liệu. 10
  12. Hai bảng GIANGDAY và LOP có mối quan hệ với nhau. Mối quan hệ này đòi hỏi giá trị cột MALOP của một dòng (tức là một lớp) trong bảng GIANGDAY phải được xác định từ cột MALOP của bảng LOP. Mối quan hệ giữa các bảng trong một cơ sở dữ liệu thể hiện đúng mối quan hệ giữa các thực thể trong thế giới thực. Mối quan hệ giữa hai bảng GIANGDAY và LOP không cho phép một MALOP nào đó tồn tại mà lại thuộc vào một MONHOC không có thật. Khái niệm khoá ngoại (Foreign Key) trong cơ sở dữ liệu quan hệ được sử dụng để biểu diễn mối quan hệ giữa các bảng dữ liệu. Một hay một tập các cột trong một bảng mà giá trị của nó được xác định từ khóa chính của một bảng khác được gọi là khoá ngoại. Cột MALOP của bảng GIANGDAY được gọi là khoá ngại của bảng GIANGDAY, khoá ngoài này tham chiếu đến khoá chính của bảng LOP là cột MALOP. 1.4 Sơ lược về SQL 1.4.1 Câu lệnh SQL SQL chuẩn nhiều câu lệnh thường được sử dụng để truy vấn và quản lý hệ cơ sở dữ liệu. Trong các hệ quản trị cơ sở dữ liệu khác nhau, mặc dù các câu lệnh đều có cùng dạng và cùng mục đích sử dụng song mỗi một hệ quản trị cơ sở dữ liệu có thể có một số thay đổi nào đó. Điều này đôi khi dẫn đến cú pháp chi tiết của các câu lệnh có thể sẽ khác nhau trong các hệ quản trị cơ cơ sở dữ liệu khác nhau. 11
  13. Câu lệnh Chức năng Thao tác dữ liệu Truy xuất dữ liệu SELECT Bổ sung dữ liệu INSERT Cập nhật dữ liệu UPDATE Xoá dữ liệu DELETE Xoá toàn bộ dữ liệu trong bảng TRUNCATE Tạo bảng Định nghĩa dữ liệu Xoa bảng CREATE TABLE Sửa đổi bảng DROP TABLE Tạo khung nhìn ALTER TABLE Sửa đổi khung nhìn CREATE VIEW Xoá khung nhìn ALTER VIEW Tạo chỉ mục DROP VIEW Xoá chỉ mục CREATE INDEX Tạo lược đồ cơ sở dữ liệu DROP INDEX Xoá lược đồ cơ sở dữ liệu CREATE SCHEMA Tạo thủ tục lưu trữ DROP SCHEMA Sửa đổi thủ tục lưư trữ CREATE PROCEDURE ALTER PROCEDURE DROP PROCEDURE Xoá thủ tục lưu trữ CREATE FUNCTION Tạo hàm (do người sử dụng định nghĩa) Các câu lệnh của SQL đều được bắt đầu bởi các từ lệnh, là một từ khoá cho biết chức năng của câu lệnh (chẳng hạn SELECT, DELETE, UPDATE). Sau từ lệnh là các mệnh đề của câu lệnh. Mỗi một mệnh đề trong câu lệnh cũng được bắt đầu bởi một từ khoá (chẳng hạn FROM, WHERE,...). Ví dụ : Câu lệnh: SELECT mahv, hoten, ngaysinh, gioitinh,lop FROM hocvien 12
  14. WHERE malop=’02ct1’ dùng để truy xuất dữ liệu trong bảng HOCVIEN được bắt đầu bởi từ lệnh SELECT, trong câu lệnh bao gồm hai mệnh đề: mệnh đề FROM chỉ định tên của bảng cần truy xuất dữ liệu và mệnh đề WHERE chỉ định điều kiện truy vấn dữ liệu. 1.4.2 Qui tắc sử dụng tên trong SQL Các đối tượng trong cơ sở dữ liệu dựa trên SQL được xác định thông qua tên của đối tượng. Tên của các đối tượng là duy nhất trong mỗi cơ sở dữ liệu. Tên được sử dụng nhiều nhất trong các truy vấn SQL và được xem là nền tảng trong cơ sở dữ liệu quan hệ là tên bảng và tên cột. Trong các cơ sở dữ liệu lớn với nhiều người sử dụng, khi chỉ định tên của một bảng nào đó trong câu lệnh SQL, hệ quản trị cơ sở dữ liệu hiểu đó là tên của bảng sở hữu (tức là bảng do người dùng tạo ra). Thông thường, trong các hệ quản trị cơ sở dữ liệu này cho phép những người dùng khác nhau tạo ra những bảng trùng tên với nhau mà không gây ra xung đột về tên. Nếu trong một câu lệnh SQL ta cần chỉ đến một bảng do một người dùng khác sở hữu (hiển nhiên là phải được phép) thì tên của bảng phải được viết sau tên của người sở hữu và phân cách với tên người sở hữu bởi dấu chấm: tên_người_sở_hữu.tên_bảng Một số đối tượng cơ sở dữ liệu khác (như khung nhìn, thủ tục, hàm), việc sử dụng tên cũng tương tự như đối với bảng. Sử dụng tên cột một cách bình thường trong các câu lệnh SQL bằng cảch chỉ cần chỉ định tên của cột trong bảng. Tuy nhiên, nếu trong câu lệnh có liên quan đến hai cột trở lên có cùng tên trong các bảng khác nhau thì bắt buộc phải chỉ định thêm tên bảng trước tên cột; tên bảng và tên cột được phân cách nhau bởi dấu chấm. Ví dụ: Ví dụ dưới đây minh hoạ cho việc sử dụng tên bảng và tên cột trong câu lệnh SQL SELECT mahv, hoten, ngaysinh, gioitinh,magv FROM hocvien WHERE giangday.malop = lop.malop 1.4.3 Kiểu dữ liệu Chuẩn ANSI/ISO SQL cung cấp các kiểu dữ liệu khác nhau để sử dụng trong các cơ sở dữ liệu dựa trên SQL và trong ngôn ngữ SQL. Dựa trên cơ sở các kiểu dữ liệu do chuẩn ANSI/ISO SQL 13
  15. cung cấp, các hệ quản trị cơ sở dữ liệu thương mại hiện nay có thể sử dụng các dạng dữ liệu khác nhau trong sản phẩm của mình. Dưới đây liệt kê một số kiểu dữ liệu thông dụng được sử dụng trong SQL. Tên kiểu Mô tả CHAR (n) Kiểu chuỗi với độ dài cố định NCHAR (n) Kiếu chuỗi với độ dài cố định hỗ trợ UNICODE VARCHAR (n) Kiểu chuỗi với độ dài chính xác NVARCHAR (n) Kiểu chuỗi với độ dài chính xác hỗ trợ UNICODE INTEGER Số nguyên có giá trị từ -231 đến 231 - 1 INT Như kiểu Integer TINYTINT Số nguyên có giá trị từ 0 đến 255. SMALLINT Số nguyên có giá trị từ -215 đến 215 – 1 BIGINT Số nguyên có giá trị từ -263 đến 263-1 NUMERIC (p,s) Kiểu số với độ chính xác cố định. DECIMAL (p,s) Tương tự kiểu Numeric FLOAT Số thực có giá trị từ -1.79E+308 đến 1.79E+308 REAL Số thực có giá trị từ -3.40E + 38 đến 3.40E + 38 MONEY Kiểu tiền tệ BIT Kiểu bit (có giá trị 0 hoặc 1) DATETIME Kiểu ngày giờ (chính xác đến phần trăm của giây) SMALLDATETIME Kiểu ngày giờ (chính xác đến phút) TIMESTAMP BINARY Dữ liệu nhị phân với độ dài cố định (tối đa 8000 bytes) VARBINARY Dữ liệu nhị phân với độ dài chính xác (tối đa 8000 bytes) IMAGE Dữ liệu nhị phân với độ dài chính xác (tối đa 2,147,483,647 bytes) TEXT Dữ liệu kiếu chuỗi với độ dài lớn (tối đa 2,147,483,647 ký tự) 14
  16. NTEXT Dữ liệu kiếu chuỗi với độ dài lớn và hỗ trợ UNICODE (tối đa 1,073,741,823 ký tự) Ví dụ: Câu lệnh dưới đây định nghĩa bảng với kiểu dữ liệu được qui định cho các cột trong bảng CREATE TABLE GIAOVIEN ( MAGV char(6), HOTEN varchar(50), GIOITINH varchar(3), NLV smalldatetime ) 1.4.4 Giá trị NULL Một cơ sở dữ liệu là sự phản ánh của một hệ thống trong thế giới thực, do đó các giá trị dữ liệu tồn tại trong cơ sở dữ liệu có thể không xác định được. Một giá trị không xác định được xuất hiện trong cơ sở dữ liệu có thể do một số nguyên nhân sau: • Giá trị đó có tồn tại nhưng không biết. • Không xác định được giá trị đó có tồn tại hay không. • Tại một thời điểm nào đó giá trị chưa có nhưng rồi có thể sẽ có. • Giá trị bị lỗi do tính toán (tràn số, chia cho không,...) Những giá trị không xác định được biểu diễn trong cơ sở dữ liệu quan hệ bởi các giá trị NULL. Đây là giá trị đặc biệt và không nên nhầm lẫn với chuỗi rỗng (đối với dữ liệu kiểu chuỗi) hay giá trị không (đối với giá trị kiểu số). Giá trị NULL đóng một vai trò quan trọng trong các cơ sở dữ liệu và hầu hết các hệ quản trị cơ sở dữ liệu quan hệ hiện nay đều hỗ trợ việc sử dụng giá trị này. 15
  17. Hệ thống kiến thức Chương 1 1. Yêu cầu về lý thuyết  Trình bày được các khái niệm trong cơ sở dữ liệu;  Trình bày được vai trò của SQL;  Trình bày được tổng quan về cơ sở dữ liệu quan hệ;  Trình bày được các sơ lược về SQL. 2. Yêu cầu về bài tập: Xác định được các khóa 3. Hệ thống các công thức đã học:  Tổng quan về SQL SQL là ngôn ngữ hỏi có cấu trúc phần nào đã liên tưởng đến một công cụ (ngôn ngữ) dùng để truy xuất dữ liệu trong các cơ sở dữ liệu, cung cấp cho người dùng bao gồm: • Định nghĩa dữ liệu: SQL cung cấp khả năng định nghĩa các cơ sở dữ liệu, các cấu trúc lưu trữ và tổ chức dữ liệu cũng như mối quan hệ giữa các thành phần dữ liệu. • Truy xuất và thao tác dữ liệu: Với SQL, người dùng có thể dễ dàng thực hiện các thao tác truy xuất, bổ sung, cập nhật và loại bỏ dữ liệu trong các cơ sở dữ liệu. • Điều khiển truy cập: SQL có thể được sử dụng để cấp phát và kiểm soát các thao tác của người sử dụng trên dữ liệu, đảm bảo sự an toàn cho cơ sở dữ liệu • Đảm bảo toàn vẹn dữ liệu: SQL định nghĩa các ràng buộc toàn vẹn trong cơ sở dữ liệu nhờ đó đảm bảo tính hợp lệ và chính xác của dữ liệu trước các thao tác cập nhật cũng như các lỗi của hệ thống.  Vai trò của SQL Trong hầu hết các hệ quản trị cơ sở dữ liệu quan hệ, SQL có những vai trò như sau: • SQL là ngôn ngữ hỏi có tính tương tác: Người sử dụng có thể dễ dàng thông qua các trình tiện ích để gởi các yêu cầu dưới dạng các câu lệnh SQL đến cơ sở dữ liệu và nhận kết quả trả về từ cơ sở dữ liệu • SQL là ngôn ngữ lập trình cơ sở dữ liệu: Các lập trình viên có thể nhúng các câu lệnh SQL vào trong các ngôn ngữ lập trình để xây dựng nên các chương trình ứng dụng giao tiếp với cơ sở dữ liệu 16
  18. • SQL là ngôn ngữ quản trị cơ sở dữ liệu: Thông qua SQL, người quản trị cơ sở dữ liệu có thể quản lý được cơ sở dữ liệu, định nghĩa các cấu trúc lưu trữ dữ liệu, điều khiển truy cập cơ sở dữ liệu. • SQL là ngôn ngữ cho các hệ thống khách/chủ (client/server): Trong các hệ thống cơ sở dữ liệu khách/chủ, SQL được sử dụng như là công cụ để giao tiếp giữa các trình ứng dụng phía máy khách với máy chủ cơ sở dữ liệu. • SQL là ngôn ngữ truy cập dữ liệu trên Internet: Cho đến nay, hầu hết các máy chủ Web cũng như các máy chủ trên Internet sử dụng SQL với vai trò là ngôn ngữ để tương tác với dữ liệu trong các cơ sở dữ liệu. • SQL là ngôn ngữ cơ sở dữ liệu phân tán: Đối với các hệ quản trị cơ sở dữ liệu phân tán, mỗi một hệ thống sử dụng SQL để giao tiếp với các hệ thống khác trên mạng, gởi và nhận các yêu cầu truy xuất dữ liệu với nhau.  Mô hình dữ liệu quan hệ Mô hình dữ liệu quan hệ được Codd đề xuất năm 1970 và đến nay trở thành mô hình được sử dụng phổ biến trong các hệ quản trị cơ sở dữ liệu thương mại.  Sơ lược về SQL - Table: Trong cơ sở dữ liệu quan hệ, bảng là đối tượng được sử dụng để tổ chức và lưu trữ dữ liệu. Một cơ sở dữ liệu bao gồm nhiều bảng và mỗi bảng được xác định duy nhất bởi tên bảng - Khóa: mỗi một bảng phải có một hoặc một tập các cột mà giá trị dữ liệu của nó xác định duy nhất một dòng trong một tập các dòng của bảng. Tập một hoặc nhiều cột có tính chất này được gọi là khoá của bảng 4. Các bài tập chương 1 Cho Cơ sở dữ liệu quản lý giảng dạy gồm có các quan hệ sau HOCVIEN (MAHV, HO, TEN, NGAYSINH, GIOITINH, NOISINH, MALOP) Tân từ: mỗi học viên phân biệt với nhau bằng mã học viên, lưu trữ họ, tên, ngày sinh, giới tính, nơi sinh, thuộc lớp nào. 17
  19. LOP (MALOP, TENLOP, LOPTRG, SISO, MAGVCN, MACVHT, MACBQL) Tân từ: mỗi lớp gồm có mã lớp, tên lớp, lớp trưởng của lớp, sỉ số lớp , mã giáo viên chủ nhiệm, mã cố vấn học tập, mã cán bộ quản lý. MONHOC (MAMH, TENMH, SOTC) Tân từ: mỗi môn học cần lưu trữ tên môn học, tên số tín chỉ GIAOVIEN (MAGV, HOTEN, GIOITINH, NLV) Tân từ: mã giáo viên để phân biệt giữa các giáo viên, cần lưu trữ họ tên, giới tính, năm làm việc. GIANGDAY (MALOP, MAMH, MAGV, HOCKY, NAM) Tân từ: mỗi học kỳ của năm học sẽ phân công giảng dạy: lớp nào học môn gì do giáo viên nào phụ trách. Yêu cầu: 1. Xác định các khóa chính của từng bảng 2. Xác định các mối quan hệ giữa các bảng 18
  20. CHƯƠNG 2: NGÔN NGỮ ĐỊNH NGHĨA DỮ LIỆU Mục tiêu bài học  Trình bày được cách tạo, xóa bảng dữ liệu;  Trình bày được cách xóa bảng dữ liệu;  Trình bày được cập nhật cơ sở dữ liệu; 19
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2