the_end_kiss0901
New Member
Download miễn phí Giáo án SQL Server
Mục Lục
Bài 1: Giới Thiệu SQL Server 2000 1
1.1. Cài Ðặt SQL Server 2000 (Installation) 1
1.2. Một chút kiến thức về các phiên bản của SQL Server 2
1.3. Các thành phần quan trọng trong SQL Server 2000 2
1.3.1. Relational Database Engine 3
1.3.2. Replication 3
1.3.3. Data Transformation Service (DTS 3
1.3.4. Analysis Service - 3
1.3.5. English Query - 3
1.3.6. Meta Data Service: 3
1.3.7. SQL Server Books Online - 3
1.3.8. SQL Server Tools - 4
Bài 2: Giới Thiệu Sơ Lược Về Transact SQL (T-SQL) 5
2.1. Data Definition Language (DDL): 5
2.2. Data Control Language (DCL): 5
2.3. Manipulation Language (DML): 6
Bài 3: Design and Implement a SQL Server Database 10
3.1. Cấu Trúc Của SQL Server 10
3.2. Cấu Trúc Vật Lý Của Một SQL Server Database 10
3.3. Nguyên Tắc Hoạt Ðộng Của Transaction Log Trong SQL Server 11
3.4. Cấu Trúc Logic Của Một SQL Server Database 13
3.5. Cách tạo một User Database 14
3.6. Những Ðiểm Cần Lưu Ý Khi Thiết Kế Một Database 16
Bài 4: Backup And Restore SQL Server 19
4.1. Chiến Lược Phục Hồi Dữ Liệu (Data Restoration Strategy) 19
4.2. Các Loại Backup 19
4.3. Recovery Models 19
4.4. Backup Database 22
4.5. Restore Database 23
Bài 5: Data Integrity and Advanced Query Technique 26
5.1. Các Phương Pháp Ðảm Bảo Data Integrity 26
5.2. Constraints 26
5.3. Advanced Query Techniques 29
5.4. Using JOINS 31
Bài 6: Stored Procedure and Advance T-SQL 33
6.1. Sử dụng bcp và BULK INSERT để import data 33
6.2. Distributed Queries 34
6.3. Cursors 35
6.4. Stored Procedures 36
6.4.1. Ưu Ðiểm Của Stored Procedure 36
6.4.2. Các Loại Stored Procedure 37
6.4.3. Viết Stored Procedure 37
Bài 7: Triggers And Views 40
http://cloud.liketly.com/flash/edoc/jh2i1fkjb33wa7b577g9lou48iyvfkz6-swf-2014-01-07-giao_an_sql_server.Sr5sqNEhNj.swf /tai-lieu/de-tai-ung-dung-tren-liketly-53944/
Để tải bản Đầy Đủ của tài liệu, xin Trả lời bài viết này, Mods sẽ gửi Link download cho bạn sớm nhất qua hòm tin nhắn.
Ai cần download tài liệu gì mà không tìm thấy ở đây, thì đăng yêu cầu down tại đây nhé:
Nhận download tài liệu miễn phí
Tóm tắt nội dung tài liệu:
xuyên dùng một số câu lệnh SQL (thường dùng các câu lệnh bắt đầu bằng DBCC .Phần này sẽ được bàn qua trong các bài sau) kiểm tra xem có đủ khoảng trống hay không nếu không đủ ta có thể chọn một thời điểm mà SQL server ít bận rộn nhất (như ban đêm hay sau giờ làm việc) để nới rộng data file như thế sẽ không làm ảnh hưởng tới performance của Server.Chú ý giả sử ta dành sẵn 2 GB cho datafile, khi dùng Window Explorer để xem ta sẽ thấy kích thước của file là 2 GB nhưng data thực tế có thể chỉ chiếm vài chục MB mà thôi.
3.6. Những Ðiểm Cần Lưu Ý Khi Thiết Kế Một Database
Trong phạm vi bài này chúng ta không thể nói sâu về lý thuyết thiết kế database mà chỉ đưa ra một vài lời khuyên mà bạn nên tuân theo khi thiết kế.
Trước hết bạn phải nắm vững về các loại data type. Ví dụ bạn phải biết rõ sự khác biệt giữa char(10), nchar(10) varchar(10), nvarchar(10). Loại dữ liệu Char là một loại string có kích thước cố định nghĩa là trong ví dụ trên nếu data đưa vào "This is a really long character string" (lớn hơn 10 ký tự) thì SQL Server sẽ tự động cắt phần đuôi và ta chỉ còn "This is a". Tương tự nếu string đưa vào nhỏ hơn 10 thì SQL sẽ thêm khoảng trống vào phía sau cho đủ 10 ký tự. Ngược lại loại varchar sẽ không thêm các khoảng trống phía sau khi string đưa vào ít hơn 10. Còn loại data bắt đầu bằng chữ n chứa dữ liệu dạng unicode.
Một lưu ý khác là trong SQL Server ta có các loại Integer như : tinyint, smallint, int, bigint. Trong đó kích thước từng loại tương ứng là 1,2,4,8 bytes. Nghĩa là loại smallint tương đương với Integer và loại int tương đương với Long trong VB.
Khi thiết kế table nên:
Có ít nhất một cột thuộc loại ID dùng để xác định một record dễ dàng.
Chỉ chứa data của một entity (một thực thể)
Trong ví dụ sau thông tin về Sách và Nhà Xuất Bản được chứa trong cùng một table
Books
BookID
Title
Publisher
PubState
PubCity
PubCountry
1
Inside SQL Server 2000
Microsoft Press
CA
Berkely
USA
2
Windows 2000 Server
New Riders
MA
Boston
USA
3
Beginning Visual Basic 6.0
Wrox
CA
Berkely
USA
Ta nên tách ra thành table Books và table Publisher như sau:
Books
BookID
Title
PublisherID
1
Inside SQL Server 2000
P1
2
Windows 2000 Server
P2
3
Beginning Visual Basic 6.0
P3
và
Publishers
PublisherID
Publisher
PubState
PubCity
PubCountry
P1
Microsoft Press
CA
Berkely
USA
P2
New Riders
MA
Boston
USA
P3
Wrox
CA
Berkely
USA
Tránh dùng cột có chứa NULL và nên luôn có giá trị Default cho các cột
Tránh lập lại một giá trị hay cột nào đó
Ví dụ một cuốn sách có thể được viết bởi hơn một tác giả và như thế ta có thể dùng một trong 2 cách sau để chứa data:
Books
BookID
Title
Authors
1
Inside SQL Server 2000
John Brown
2
Windows 2000 Server
Matthew Bortniker, Rick Johnson
3
Beginning Visual Basic 6.0
Peter Wright, James Moon, John Brown
hay
Books
BookID
Title
Author1
Author2
Author3
1
Inside SQL Server 2000
John Brown
Null
Null
2
Windows 2000 Server
Matthew Bortniker
Rick Johnson
Null
3
Beginning Visual Basic 6.0
Peter Wright
James Moon
John Brown
Tuy nhiên việc lập đi lập lại cột Author sẽ tạo nhiều vấn đề sau này. Chẳng hạn như nếu cuốn sách có nhiều hơn 3 tác giả thì chúng ta sẽ gặp phiền phức ngay....Trong ví dụ này ta nên chặt ra thành 3 table như sau:
Books
BookID
Title
1
Inside SQL Server 2000
2
Windows 2000 Server
3
Beginning Visual Basic 6.0
Authors
AuthID
First Name
Last Name
A1
John
Brown
A2
Matthew
Bortniker
A3
Rick
Johnson
A4
Peter
Wright
A5
James
Moon
AuthorBook
BookID
AuthID
1
A1
2
A2
2
A3
3
A4
3
A5
3
A1
Ngoài ra một trong những điều quan trọng là phải biết rõ quan hệ (Relationship) giữa các table:
One-to-One Relationships : trong mối quan hệ này thì một hàng bên table A không thể liên kết với hơn 1 hàng bên table B và ngược lại.
One-to-Many Relationships : trong mối quan hệ này thì một hàng bên table A có thể liên kết với nhiều hàng bên table B.
Many-to-Many Relationships : trong mối quan hệ này thì một hàng bên table A có thể liên kết với nhiều hàng bên table B và một hàng bên table B cũng có thể liên kết với nhiều hàng bên table A. Như ta thấy trong ví dụ trên một cuốn sách có thể được viết bởi nhiều tác giả và một tác giả cũng có thể viết nhiều cuốn sách. Do đó mối quan hệ giữa Books và Authors là quan hệ Many to Many. Trong trường hợp này người ta thường dùng một table trung gian để giải quyết vấn đề (table AuthorBook).
Ðể có một database tương đối hoàn hảo nghĩa là thiết kế sao cho data chứa trong database không thừa không thiếu bạn cần biết thêm về các thủ thuật Normalization. Tuy nhiên trong phạm vi khóa học này chúng tui không muốn bàn sâu hơn về đề tài này, bạn có thể xem thêm trong các sách dạy lý thuyết cơ sở dữ liệu.
Bài 4: Backup And Restore SQL Server
4.1. Chiến Lược Phục Hồi Dữ Liệu (Data Restoration Strategy)
Có một điều mà chúng ta phải chú ý là hầu như bất kỳ database nào cũng cần được phục hồi vào một lúc nào đó trong suốt chu kỳ sống của nó. Là một người Database Administrator bạn cần 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 data file hay Transaction Log File hay system file 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 hay 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 user như lỡ tay delete toàn bộ table 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.
4.2. Các Loại 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 backup trong SQL Server
Full Database Backups : Copy tất cả data files 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ả data files kể từ lần full backup gần nhất.
File or File Group Backups : Copy một data file đơn hay một file group.
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 transactions chứa trong transaction log file kể từ lần transaction log backup gần nhất. Loại backup 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 ngưng lại.
4.3. Recovery Models
Full Recovery Model : Ðây là mo...