Giáo trình mô đun Hệ quản trị cở dữ liệu - Nghề: Lập trình viên máy tính

Bài 1: TỔNG QUAN VỀ HỆ QUẢN TRỊ CSDL SQL SERVER

Mã bài: MĐLTV13.01

Giới thiệu.

Ngôn ngữ hỏi có cấu trúc (SQL), có tiền thân là SEQUEL, là một ngôn ngữ

được IBM phát triển và sử dụng trong hệ cơ sở dữ liệu thử nghiệm có tên là System/R

vào năm 1974, chính thức được ANSI/ISO công nhận là một chuẩn ngôn ngữ sử dụng

trong cơ sở dữ liệu quan hệ vào năm 1986. Cho đến hiện nay, SQL đã được sử dụng

phổ biển trong các hệ quản trị cơ sở dữ liệu thương mại và có vai trò quan trọng trong

những hệ thống này.

Vậy thực sự SQL là gì? Tại sao nó lại quan trọng trong các hệ quản trị cơ sở dữ

liệu? SQL có thể làm được những gì và như thế nào? Nó được sử dụng ra sao trong

các hệ quản trị cơ sở dữ liệu quan hệ? Nội dung của chương này sẽ cung cấp cho

chúng ta cái nhìn tổng quan về SQL và một số vấn đề liên quan.

Mục tiêu:

- Trình bày được kiến trúc, các thành phần cơ bản của hệ quản trị CSDL SQL Server.

- Trình bày được các đối tượng cơ bản của Cơ sở dữ liệu trong SQL Server

- Cài đặt và cấu hình được SQL Server

- Thực hiện được các thao tác cơ bản khi làm việc với CSDL

- Thực hiện được các thao tác cơ bản với đối tượng bảng

Nội dung chính:

1. Giới thiệu

1.1.Lịch sử ra đời và phát triển

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 làm chúng ta 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. Thực sự mà nói,

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 dù đây là mục

đích ban đầu khi SQL được xây dựng nên và truy xuất dữ liệu vẫn còn 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ệu8

• Đả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.

pdf104 trang | Chia sẻ: Thục Anh | Lượt xem: 559 | Lượt tải: 0download
Bạn đang xem trước 20 trang nội dung tài liệu Giáo trình mô đun Hệ quản trị cở dữ liệu - Nghề: Lập trình viên máy tính, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
function_name; Ví dụ mình muốn xóa function đã tạo ở trên thì chạy lệnh sau: 1 DROP FUNCTION sales.udfNetSale; Tương tự, bạn chỉ có thể xóa function do bạn tự tạo. 4. Sử dụng thủ tục trong lập trình kết nối CSDL 4.1 Khái niệm về thủ tục nội tại Giống như ý nghĩa của việc sử dụng thủ tục dùng chung trong những ngôn ngữ lập trình khác, thủ tục nội tại trong Microsoft SQL Server dùng để tạo ra những xử lý thường dùng bên trong ứng dụng và nhằm để chia nhỏ các xử lý theo mô hình thiết kế xử lý top- down, nhằm đơn giản hóa các xử lý phức tạp. Thủ tục nội tại thật sự là một tập hợp chứa các dòng lệnh, các biến, các cấu trúc điều khiển bên trong ngôn ngữ T_SQL, dùng để thực hiện một hành động nào đó, tất cả các nội dung của thủ tục nội tại sẽ được lưu trữ tại CSDL của Microsoft SQL Server. Các đặc trưng của một thủ tục nội tại : - Tên thủ tục nội tại. - Tham số truyền giá trị vào và tham số nhận giá trị trả về. - Gọi thi hành một thủ tục nội tại khác. - Phạm vi hoạt động của một thủ tục nội tại chỉ có tính cục bộ bên trong một CSDL lưu trữ thủ tục đó. - Được gọi thi hành trong môi trường không phải là Microsoft SQL Server. - Được biên dịch ở lần thi hành đầu tiên và cách hoạt động của nó được cất lại, nên các lần gọi thi hành sau nó sẽ hoạt động nhanh hơn nhiều. 4.2 Các hành động cơ bản với thủ tục nội tại 4.2.1 Tạo mới một thủ tục nội tại Cú pháp : CREATE PROC[EDURE] Tên_thủ_tục [Danh sách các tham số] AS [DECLARE Biến_cục_bộ] Các_lệnh GO 4.2.2 Gọi thực hiện một thủ tục nội tại Cú pháp : EXEC[UTE] Tên_thủ_tục 4.2.3 Hủy bỏ một thủ tục nội tại Cú pháp : DROP PROC[EDURE] Tên_thủ_tục 4.2.4 Thay đổi nội dung của một thủ tục nội tại Cú pháp : ALTER PROC[EDURE] Tên_thủ_tục AS [DECLARE biến_cục_bộ] Các _lệnh Bài 5: AN TOÀN VÀ BẢO MẬT DỮ LIỆU Mã bài: MĐLTV13.05 Mục tiêu: - Trình bày được những khái niệm cơ bản về sao lưu và phục hồi. - Trình bày được các khái niệm về log in , user, publisher - Thực hiện được sao lưu và phục hồi cơ sở dữ liệu. - Thực hiện được nhập, xuất dữ liệu. - Thực hiện được tạo và phân quyền log in, user. Phân biệt được login và User. - Cài đặt được Client để truy cập đến Server sử dụng log in được cấp. Nội dung bài: 1. Sao lưu và phục hồi cơ sở dữ liệu Chiến lược phục hồi dữ liệu (Data Restoration Strategy) Khi nào ta cần khôi phục lại dữ liệu? Có rất nhiều lý do mà người Quản trị CSDL (Database Administrator) phải đảm bảo để dữ liệu của hệ thống được chính xác, không bị sai lệch vàn cần phải giảm tối đa số lần phải phục hồi dữ liệu, luôn theo dõi, kiểm tra thường xuyên để phát hiện các trục trặc trước khi nó xảy ra. Phải dự phòng các biến cố có thể xảy ra và bảo đảm rằng có thể nhanh chóng phục hồi dữ liệu trong thời gian sớm nhất có thể được. Các dạng biến cố hay tai họa có thể xảy ra là: § Ðĩa chứa file dữ liệu hoặc file Transaction Log hay file hệ thống bị mất § Server bị hư hỏng § Những thảm họa tự nhiên như bão lụt, động đất, hỏa hoạn § Toàn bộ server bị đánh cắp hoặc phá hủy § Các thiết bị dùng để backup – restore bị đánh cắp hay hư hỏng § Những lỗi do vô ý của người sử dụng như lỡ tay xoá dữ liệu chẳng hạn § Những hành vi mang tính phá hoại của nhân viên như cố ý đưa vào những thông tin sai lạc. § Bị hack (nếu server có kết nối với internet). Bạn phải tự hỏi khi các vấn đề trên xảy ra thì bạn sẽ làm gì và phải luôn có biện pháp đề phòng cụ thể cho từng trường hợp cụ thể. Ngoài ra bạn phải xác định thời gian tối thiểu cần phục hồi dữ liệu và đưa server trở lại hoạt động bình thường. Các loại sao lưu (Backup) Ðể có thể hiểu các kiểu phục hồi dữ liệu khác nhau bạn phải biết qua các loại sao lưu trong SQL Server § Full Database Backups : Copy tất cả các file dữ liệu trong một database . Tất cả những user data và database objects như system tables, indexes, user- defined tables đều được backup. § Differential Database Backups : Copy những thay đổi trong tất cả các file dữ liệu kể từ lần backup gần nhất. § File or File Group Backups : Copy một data file đơn hay một nhóm file. § Differential File or File Group Backups : Tương tự như differential database backup nhưng chỉ copy những thay đổi trong data file đơn hay một file group. § Transaction Log Backups : Ghi nhận một cách thứ tự tất cả các giao dịch (transaction) chứa trong file transaction log kể từ lần transaction log backup gần nhất. Loại sao lưu này cho phép ta phục hồi dữ liệu trở ngược lại vào một thời điểm nào đó trong quá khứ mà vẫn đảm bảo tính đồng nhất (consistent). Trong lúc backup SQL Server cũng copy tất cả các hoạt động của database kể cả hoạt động xảy ra trong quá trình backup cho nên ta có thể backup trong khi SQL đang chạy mà không cần phải dừng lại. Các chế độ khôi phục (Recovery Models) § Chế độ Full Recovery: Ðây là chế độ cho phép phục hồi dữ liệu với ít rủi ro nhất. Nếu một database ở trong chế độ này thì tất cả các hoạt động không chỉ insert, update, delete mà kể cả insert bằng Bulk Insert, hay bcp đều được log vào file transaction log. Khi có sự cố thì ta có thể phục hồi lại dữ liệu ngược trở lại tới một thời điểm trong quá khứ. Khi file dữ liệu bị hư nếu ta có thể sao lưu được file transaction log thì ta có thể phục hồi CSDL đến thời điểm transaction gần nhất đã được xác nhận (commited). § Chế độ Bulk-Logged Recovery: Ở chế độ này các hoạt động mang tính hàng loạt như Bulk Insert, bcp, Create Index, WriteText, UpdateText chỉ được log minimum vào File Transaction Log đủ để cho biết là các hoạt động này có diễn ra mà không log toàn bộ chi tiết như trong chế độ Full Recovery. Các hoạt động khác như Insert, Update, Delete vẫn được log đầy đủ để dùng cho việc phục hồi sau này. § Chế độ Simple Recovery: Ở chế độ này thì File Transaction Log được cắt xén thường xuyên và không cần sao lưu. Với chế độ này bạn chỉ có thể phục hồi tới thời điểm backup gần nhất mà không thể phục hồi tới một thời điểm trong quá khứ. Muốn biết CSDL của bạn đang ở mode nào bạn có thể Right-click lên một database nào đó trong SQL Server Management Studio chọn Properties- >Options->Recovery model Chế độ khôi phục dữ liệu Tuy nhiên có thể tới đây bạn cảm thấy rất khó hiểu về những điều trình bày ở trên. Chúng ta hãy dùng một ví dụ sau để làm rõ vấn đề. Ví dụ: Chúng ta có một database được áp dụng chiến lược sao lưu như hình vẽ sau: Chiến lược sao lưu một Database Trong ví dụ này chúng ta lập lịch ở chế độ Full Database Backup vào ngày Chủ Nhật và Differential Backup vào các ngày thứ Ba và Thứ Năm. Transaction Log Backup được lập lịch hằng ngày. Vào một ngày Thứ Sáu “đen tối” một sự cố xảy ra đó là đĩa chứa file dữ liệu của CSDL bị hỏng và bạn là một quản trị CSDL, bạn được yêu cầu phải phục hồi dữ liệu và đưa CSDL hoạt động trở lại bình thường. Bạn phải làm sao? Trước hết bạn phải sao lưu ngay File Transaction Log (trong ví dụ này File Transaction Log được chứa trong một đĩa khác với đĩa chứa File dữ liệu nên không bị hỏng và vẫn còn hoạt động). Người ta còn gọi file sao lưu trong trường hợp này là ” the tail of the log” (phần đuôi). Nếu Log File được chứa trên cùng một đĩa với File dữ liệu thì bạn có thể sẽ không sao lưu được “phần đuôi” và như vậy bạn phải dùng đến file sao lưu log gần nhất. Khi sao lưu “phần đuôi” này bạn cần phải dùng tuỳ chọn NO_TRUNCATE bởi vì thông thường các Transaction Log Backup sẽ cắt xén những phần không cần dùng đến trong transaction log file, đó là những transaction đã được chấp nhận và đã được viết vào CSDL (còn gọi là inactive portion of the transaction log) để giảm kích thước của log file. Tuy nhiên khi sao lưu phần đuôi không được cắt xén để đảm bảo tính nhất quán (consistent) của database. Kế đến bạn phải khôi phục CSDL (restore database) từ File Full Backup của ngày Chủ Nhật. Nó sẽ làm 2 chuyện : copy dữ liệu, log, index từ đĩa sao lưu vào các file dữ liệu và sau đó sẽ lần lượt thực thi các transaction trong transaction log. Lưu ý ta phải dùng tuỳ chọn WITH NORECOVERY trong trường hợp này (tức là tuỳ chọn thứ 2 “Leave database nonoperational but able to restore additional transaction logs” trong SQL Server Management Studio). Nghĩa là các transaction chưa hoàn tất (incomplete transaction) sẽ không được roll back. Như vậy CDSL lúc này sẽ ở trong tình trạng inconsistent và không thể dùng được. Nếu ta chọn WITH RECOVERY (hay “Leave database operational. No additional transaction logs can be restored ” trong SQL Server Management Studio) thì các incomplete transaction sẽ được roll back và CSDL ở trạng thái consistent nhưng ta không thể nào khôi phục các transaction log backup được nữa. Tiếp theo bạn phải khôi phục Differential Backup của ngày Thứ Năm. Sau đó lần lượt khôi phục các Transaction Log Backup kể từ sau lần Differential Backup cuối cùng nghĩa là restore Transaction Log Backup của ngày Thứ Năm và “Phần Ðuôi”. Như vậy ta có thể phục hồi data trở về trạng thái trước khi biến cố xảy ra. Quá trình này gọi là phục hồi CSDL (Database Recovery). Cũng xin làm rõ cách dùng từ Database Restoration và Database Recovery trong SQL Server. Hai từ này nếu dịch ra tiếng Việt đều có nghĩa là phục hồi cơ sở dữ liệu nhưng khi đọc sách tiếng Anh phải cẩn thận vì nó có nghĩa hơi khác nhau. Như trong ví dụ trên khi ta restore database từ một file backup nghĩa là chỉ đơn giản tái tạo lại database từ những file backup và thực thi lại những transaction đã được commit nhưng database có thể ở trong trạng thái inconsistent và không sử dụng được. Nhưng khi nói đến recover nghĩa là ta không chỉ phục hồi lại data mà còn bảo đảm cho nó ở trạng thái consistent và sử dụng được (usable). Có thể bạn sẽ hỏi consistent là thế nào? Phần này sẽ được trình bày trong bài về Tính toàn ven dữ liệu (Data Integrity). Bạn có thể xem lại ví dụ về Transaction Log ở bài trước : Giả sử số tiền VND 500000 được trừ khỏi tài khoản A nhưng lại không được cộng vào tài khoản B và nếu CSDL không được quá trình khôi phục dữ liệu tự động (automatic recovery process) của SQL rollback thì nó sẽ ở trạng thái không đồng nhất. Nếu CSDL ở trạng thái giống như trước khi trừ tiền hoặc sau khi đã cộng VND 500000 thành công vào tài khoản B thì gọi là đồng nhất. Cho nên việc sao lưu File Transaction Log sẽ giúp cho việc recovery dữ liệu tới bất kỳ thời điểm nào trong quá khứ. Ðối với chế độ Simple Recovery ta chỉ có thể recover tới lần sao lưu gần nhất mà thôi. Như vậy khi restore database ta có thể chọn tuỳ chọn WITH RECOVERY để roll back các transaction chưa được commited và CSDL có thể hoạt động bình thường nhưng ta không thể restore thêm backup file nào nữa, thường tuỳ chọn này được chọn khi restore file backup cuối cùng trong chuỗi backup. Nếu chọn tuỳ chọn WITH NORECOVERY các transaction chưa được commited sẽ không được roll back do đó SQL Server sẽ không cho phép ta sử dụng database nhưng ta có thể tiếp tục restore các file backup kế tiếp, thường option này được chọn khi sau đó ta còn phải restore các file backup khác. Không lẽ chỉ có thể chọn một trong hai option trên mà thôi hay sao? Không hoàn toàn như vậy ta có thể chọn một tuỳ chọn trung lập hơn là tuỳ chọn WITH STANDBY (tức là tuỳ chọn 3 “Leave database read-only and able to restore additional transaction logs” trong SQL Server Management Studio). Với tuỳ chọn này ta sẽ có luôn đặc tính của hai tuỳ chọn trên : các incomplete transaction sẽ được roll back để đảm bảo sự đồng nhất của CSDLvà có thể sử dụng được nhưng chỉ dưới dạng Read-only mà thôi, đồng thời sau đó ta có thể tiếp tục restore các file backup còn lại (SQL Server sẽ log các transaction được roll back trong undo log file và khi ta restore backup file kế tiếp SQL Server sẽ trả lại trạng thái no recovery từ những gì ghi trên undo file). Người ta dùng option này khi muốn restore database trở lại một thời điểm nào đó (a point in time) nhưng không rõ là đó có phải là thời điểm mà họ muốn không, cho nên họ sẽ restore từng backup file ở dạng Standby và kiểm chứng một số data xem đó có phải là thời điểm mà họ muốn restore hay không (chẳng hạn như trước khi bị delete hay trước khi một transaction nào đó được thực thi) trước khi chuyển sang Recovery option. 1.1. Sao lưu CSDL – Backup Database Trong phần này chúng ta sẽ bàn về cách sao lưu CSDL. Nhưng trước hết chúng ta hãy làm quen với một số thuật ngữ dùng trong quá trình sao lưu và phục hồi. Có những từ ta sẽ để nguyên tiếng Anh mà không dịch. Thuật Ngữ Giải Thích Backup Quá trình copy toàn bộ hay một phần của database, transaction log, file hay file group hình thành một backup set. Backup set được chứa trên backup media (tape or disk) bằng cách sử dụng một backup device (tape drive name hoặc physical filename) Backup Device Định nghĩa việc sao lưu một Device logic tới một file trên ổ đĩa. Một device logic là tên người dùng tự định nghĩa mà trỏ tới một device sao lưu vật lý (như C:\SQLBackups\Full.bak) hoặc tape drive (như \\.\Tape0). Backup File chứa một backup set Thuật Ngữ Giải Thích File Backup Media Disk hay tape được sử dụng để chứa một backup set. Backup media có thể chứa nhiều backup sets (ví dụ như từ nhiều SQL Server 2000 backups và từ nhiều Windows 2000 backups). Backup Set Một bộ backup từ một lần backup đơn được chứa trên backup media. a. Backup Device Chúng ta có thể tạo một backup device cố định (permanent) hay tạo ra một backup file mới cho mỗi lần backup. Thông thường chúng ta sẽ tạo một backup device cố định để có thể dùng đi dùng lại đặc biệt cho việc tự động hóa công việc backup. Ðể tạo một backup device dùng SQL Management Studio bạn làm như sau: Cách sao lưu backup device § Sau khi kết nối tới một instance thích hợp của Microsoft SQL Server Database Engine, trong cửa sổ Object Explorer, kích vào tên Server hiển thị cây các đối tượng trong mục này. § Mở Server Objects, và kích chuột phải Backup Devices. § Kích New Backup Device. Hộp thoại Backup Device mở ra. § Nhập vào Device Name. § Phần Destination, kích File và chỉ định đường dẫn đầy đủ của file. § Hoàn thành bằng cách kích nút OK. Ngoài ra bạn có thể dùng một stored procedure có tên sp_addumpdevice như ví dụ sau: § Kết nối tới Microsoft SQL Server Database Engine. § Từ trên thanh Toolbar chuẩn, kích New Query. § Copy và paste ví dụ sau vào cửa sổ query và kích Execute. Ví dụ này giới thiệu cách sử dụng sp_addumpdevice để định nghĩa một logical backup device cho một file của đĩa. Ví dụ này thêm thiết bị sao lưu đĩa có tên mydiskdump tới một tên vật lý C:\SQLBackups\Full.bak. USE Master Go Sp_addumpdevice 'disk' , 'mydiskdump' , 'C:\SQLBackups\Full.bak' b. Backup database Ðể backup database bạn có thể dùng Backup Wizard hoặc kích lên trên tên database muốn backup sau đó kích chuột phải chọn Tasks->Back Up sẽ hiện ra cửa sổ như sau: Cách sao lưu Database Sau đó dựa tùy theo yêu cầu của database mà chọn các option thích hợp. Ta có thể schedule cho SQL Server backup định kỳ. 1.2.Khôi phục CSDL – Restore Database Trước khi khôi phục CSDL ta phải xác định được thứ tự file cần khôi phục. Các thông tin này được SQL Server chứa trong CSDL msdb và sẽ cho ta biết backup device nào, ai backup vào thời điểm nào. Sau đó ta tiến hành restore. Ðể khôi phục CSDL kích chuột phải ->Tasks ->Restore -> Database sẽ thấy cửa sổ như sau: Khôi phục cơ sở dữ liệu Chú ý: Nếu bạn khôi phục CSDL từ một instance khác của SQL Server hay từ một server khác bạn nên lựa chọn From device và chọn file backup tương ứng . Nếu bạn muốn ghi đè cơ sở dữ liệu có sẵn với dữ liệu được sao lưu bạn có thể chọn tuỳ chọn Overwrite the existing database như hình: Các tuỳ chọn khôi phục CSDL Bạn có thể chọn leave database operational hoặc nonoperational tùy theo trường hợp như đã giải thích ở trên. 2. Import và Export cơ sở dữ liệu 2.1. Import database MySQL: Nhập database mysql Để thực hiện nhập lại database bạn cần có file .sql chứa dữ liệu cần được nhập. File dữ liệu có thể ở dạng text với đuôi .sql hoặc ở dạng nén Gzip với đuôi .sql.gz Tiến hành đăng nhập vào Control Panel của Hostinger tại địa chỉ https://cpanel.hostinger.vn. Tiếp tục chọn vào nút Quản lý ở host cần nhập. Tiếp theo, bạn hãy bấm chọn vào phpMyAdmin tại mục MySQL Databases. Các bước import database MySQL như sau: Click vào icon phpMyAdmin trong phần Databases trong control panel của Hostinger Chọn database của bạn (hoặc tạo mới một database), nhấn vào nút “Vào phpMyAdmin” Khi đã vào được giao diện phpMyAdmin để quản lý database của bạn, tiến hành import database MySQL. Nếu database đang chứa dữ liệu, điều đầu tiên cần thực hiện là xóa tất cả các dữ liệu của database này trước khi nhập nếu không có thể gặp lỗi. Để xóa các dữ liệu có sẵn, chọn database của bạn: Bấm vào mục Select all để chọn tất cả các table và nhấn nút Drop như hình bên trên để tiến hành xóa tất cả các dữ liệu hiện có. Bạn chỉ thực hiện bước này khi muốn nhập lại database cho một database đã có dữ liệu trước đó. Nếu bạn tạo mới một database để nhập thì có thể bỏ qua bước này. Sau khi xóa database, hãy tiếp tục chọn Import ở menu ngang bên trên. Bước tiếp theo, bạn sẽ chọn file sql trên máy của bạn để upload lên. File sql này có thể ở dạng text .sql hay dạng nén với đuôi .sql.zip hay .sql.gz đều được. Bấm vào nút Choose File để chọn file database cần nhập, bấm tiêp Go để quá trình tải lên và nhập vào database của bạn. Khi phpMyAdmin chạy và hiện thông báo tương tự: Import has been successfully finished, 302 queries executed. (u377365733_db.sql.gz) nghĩa là quá trình nhập database đã thành công. 2.2. Export database MySQL – Trích xuất DB Việc xuất ra database cũng được thực hiện tương tự như lúc nhập. Cơ bản bạn chỉ cần chọn database cần export và truy cập vào giao diện phpMyAdmin của database đó. Sau đó chọn mục Export ở menu ngang bên trên, các tùy chọn khác để mặc định rồi nhấp nút Go để Export database MySQL về máy tính. Tóm lại các bước export MySQL database đơn giản như sau: Truy cập vào phpMyAdmin của Database Chọn Export Chọn Quick (hoặc Custom và chọn tất cả các bạn) Hãy chắc rằng format là SQL Bạn cũng có thể chọn xuất dữ liệu từ một table nào đó theo yêu cầu mà không phải là toàn bộ table trong database. 3.Tạo tài khoản người dùng và phân quyền Bảo mật cơ sở dữ liệu sql server là giải pháp cho phép các quản trị viên cơ sở dữ liệu thiết lập quyền hạn cho người dùng hoặc nhóm người dùng khai thác cơ sở dữ liệu. Người dùng hoặc nhóm người dùng sau khi được cấp quyền, có thể đăng nhập vào hệ thống và thực hiện các quyền hạn mà mình được cấp. Bảo mật cơ sở dữ liệu sql server giúp phân quyền người dùng trên cơ sở dữ liệu. Hình bên dưới là một ví dụ về phân quyền trên cơ sở dữ liệu Tình huống bảo mật cơ sở dữ liệu sql server Cấp quyền cho người dùng tên test1 được phép xem dữ liệu trên bảng VATTU của cơ sở dữ liệu QuanLyBanHang Các bước thực hiện bảo mật cơ sở dữ liệu sql server – Cấp quyền cho người dùng Đăng nhập vào hệ thống với quyền quản trị (Administrator) và thực hiện một trong hai cách sau: Cách 1: Thực hiện bằng giao diện Bước 1: Tạo tài khoản sql server (login) Bước 2: Tạo người sử dụng (user) Bước 3: Cấp quyền cho người dùng Chuột phải lên bảng (table) hoặc cơ sở dữ iệu (Database) -> chọn Properties Thiết lập quyền Bảo mật cơ sở dữ liệu sql server – Thiết lập chế độ chứng thực Windows và SQL Server Bước 1: Đăng nhập vào SQL Server bằng chứng thực Windows với quyền admin Bước 2: Chuột phải lên trên cùng -> chọn Properties Bước 3: Chọn SQL Server and Windows Authencation mode Bước 4: Khởi động lại SQL Server Bảo mật cơ sở dữ liệu sql server – Bài tập thực hành số 1 Cho phép người dùng test2 được phép xem tất cả dữ liệu của cơ sở dữ liệu QuanLyBanHang. Lưu ý: Kiểm tra quyền của người dùng này bằng cách sử dụng máy tính khác kết nối từ xa vào máy chủ (kết nối thông qua mạng LAN) Cách 2: Thực hiện bằng câu lệnh Bước 1: Tạo tài khoản đăng nhập Cách 1: create login tên_login with password = 'nhập_mật_khẩu' Cách 2: sp_addlogin 'tên_login','mật_khẩu' Bước 2: Tạo người dùng Cách 1: create user tên_user for login tên_login Cách 2: sp_adduser 'tên_login','tên_user' Bước 3: Cấp quyền cho người dùng grant danh_sách_quyền on tên_bảng to tên_user [with grant option] Tuỳ chọn [with grant option] được sử dụng để cho phép người dùng được phép cấp lại những quyền của mình cho người dùng khác. Bảo mật cơ sở dữ liệu sql server – Ví dụ cấp quyền cho người dùng Tình huống: Cấp quyền xem và thêm dữ liệu trên bảng VATTU cho người dùng thanhnv. Các bước thực hiện: Bước 1: Tạo tài khoản đăng nhập create login thanhnv with password = 'Abc12345' Bước 2: Tạo người dùng create user thanhnv for login thanhnv Bước 3: Cấp quyền grant select,insert on VATTU to thanhnv Bài tập vận dụng: Cấp quyền xem và thêm trên bảng NHACC và bảng VATTU cho người dùng tên test3. Lưu ý khi chúng ta muốn cấp quyền trên các cột, chúng ta phải chỉ định các cột được cấp như cú pháp bên dưới: Cách 1: grant select(danh_sách_cột) on tên_bảng to tên_user Cách 2: grant select on tên_bảng(danh_sách_cột) to tên_user Ví dụ chỉ cho pháp người dùng thanhnv được phép xem 2 cột masv và tensv của bảng SINHVIEN grant select(masv,tensv) on sinhvien to thanhnv Bảo mật cơ sở dữ liệu sql server – Windows Authencation Bước 1: Tạo tài khoản đăng nhập hệ điều hành Windows, chúng ta có thể sử dụng câu lệnh sau và thực hiện trong CMD của Windows net user accountName accountPassword /add Sử dụng SQL Server Management Studio và thực hiện các bước sau Bước 2: Tạo login ánh xạ đến tài khoản đăng nhập Windows create login "hostName\accountName" from windows Bước 3: Tạo user create user userName for login "hostName\acountName" Bước 4: Cấp quyền cho user grant permission on tableName to userName [with grant option] Các bước thực hiện bảo mật cơ sở dữ liệu sql server – Cấp quyền cho nhóm Nhóm trong SQL Server bao gồm 1 hoặc nhiều user, điều này cũng tương tự như trong công ty hoặc tổ chức mỗi phòng ban có 1 hoặc nhiều nhân viên. Bên dưới là ví dụ về sơ đồ tổ chức của một công ty. Như vậy thay vì chúng ta cấp quyền cho từng user, người quản trị có thể cấp quyền theo nhóm. Và những user thuộc nhóm quyền nào sẽ có tất cả quyền của nhóm đó. Do đó, khi người quản trị thực hiện thêm bớt quyền sẽ dễ dàng hơn. Bước 1: Tạo nhóm Cách 1: Create Role Tên_Nhóm Cách 2: Sp_AddRole 'Tên_Nhóm' Bước 2: Cấp quyền cho nhóm Grant Quyền On Bảng To Tên_Nhóm Bước 3: Thêm user vào nhóm Sp_AddRoleMember 'Tên_Nhóm', 'Tên_User' Ví dụ cấp quyền cho nhóm xemdulieu quyền xem dữ liệu cơ sở dữ liệu QuanLyBanHang. Trong nhóm quyền này có một user là DangLH Bước 1: Tạo nhóm quyền Use QuanLyBanHang --Chọn cơ sở dữ liệu Create role xemdulieu Bước 2: Cấp quyền cho nhóm Grant select to xemdulieu Bước 3: Tạo login tên DangLH, mật khẩu Abc12345 Create Login DangLH With Password = 'Abc12345' Bước 4: Tạo user DangLH sử dụng login DangLH Use QuanLyBanHang --Chọn cơ sở dữ liệu Create User DangLH For Login DangLH Bước 5: Thêm usser DangLH vào nhóm xemdulieu Sp_addRoleMember 'xemdulieu', 'DangLH' Luu ý: Đăng nhập vào tài khoản DangLH để kiểm tra quyền đã được cấp cho nhóm xemdulieu Bảo mật cơ sở dữ liệu sql server – Bài tập thực hành số 2 Câu 1: Tạo tài khoản 1.1 Tạo tài khoản đăng nhập SQLServer với tên đăng nhập là nhanvien và password là 123456 1.2 Tạo tài khoản đăng nhập SQLServer với tên đăng nhập là giamdoc và password là giamdoc 1.3 Tạo login có tên là thukho với password là thukho Câu 2: Tạo người dùng 2.1 Tạo người dùng có tên nhanvien với tài khoản đăng nhập là nhanvien 2.2 Tạo người dùng có tên giamdoc với tài khoản đăng nhập là giamdoc 2.3 Tạo người dùng tên thukho với tên login là thukho Câu 3: Cấp quyền 3.1 Cấp quyền cho những người dùng có tên là : nhanvien, giamdoc quyền thực thi các câu lệnh SELECT, INSERT và UPDATE trên bảng VATTU. 3.2 Cho phép những người dùng nhanvien, giamdoc quyền xem : năm tháng, mã vật tư, số lượng đầu, số lượng cuối trên bảng TONKHO (cột NAMTHANG, MAVTU, SLDAU, SLCUOI của bảng TONKHO). 3.3 Cấp quyền cho những người dùng nhanvien, giamdoc quyền SELECT, INSERT, UPDATE, DELETE trên bảng NHACC (Nhà cung cấp). 3.4 Cho phép người dùng thukho quyền xem dữ liệu trên bảng TONKHO, đồng thời có thể cấp lại quyền này cho những người dùng khác 3.5 Cấp quyền tạo cơ sở dữ liệu (Create Database) và tạo bảng (Create Table) cho người dùng có tên là giamdoc. Bảo mật cơ sở dữ liệu sql server – Bài tập thực hành số 3 Câu 1: Sử dụng tài khoản với quyền quản trị thực hiện tạo login, user và cấp quyền 1.1 Tạo login tên admin1, mật khẩu Abc12345 1.2 Tạo user thuộc cơ sở dữ liệu master (Databases->System Databases->master) 1.3 Cấp quyền tạo cơ sở dữ liệu, tạo bảng và quyền tạo login cho admin1 Câu 2: Sử dụng tài khoản admin1 và thực hiện các yêu cầu sau 2.1 Tạo CSDL QuanLyNhanSu File Size MaxSize FileGrowth Data 100 Không giới hạn 50 Log 300 Không giới hạn 100 2.2 Tạo bảng NhanVien và LuongNV thuộc CSDL QuanLyNhanSu Bảng NhanVien Tên cột Kiểu dữ liệu Số kí tự Ghi chú MaNv varchar 20 Khóa chí

Các file đính kèm theo tài liệu này:

  • pdfgiao_trinh_mo_dun_he_quan_tri_co_du_lieu_nghe_lap_trinh_vien.pdf