Truy cập cơ sở dữ liệu với .NET - Các cố gắng thay đổi DataSet
lượt xem 8
download
Sau khi soạn thạo dữ liệu trong một DataSet, cũng có những lúc cần phải thay đổi nó. Một ví dụ khá phổ biến đó là chọn dữ liệu từ một cơ sở dữ liệu, biểu diễ nó cho người dùng, và cập nhật cho cơ sở dữ liệu. Cập nhật với các Data Adapter Một SqlDataAdapter có thể bao gồm SelectCommand, một InsertCommand, UpdateCommand, và DeleteCommand. Giống như tên gọi, những đối tượng này là những thể hiện của SqlCommand (hoặc OleDbCommand dùng cho OleDbDataAdapter), vì vậy những câu lệnh này có thể chuyển thành SQL hoặc một...
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Truy cập cơ sở dữ liệu với .NET - Các cố gắng thay đổi DataSet
- Truy cập cơ sở dữ liệu với .NET Các cố gắng thay đổi DataSet Sau khi soạn thạo dữ liệu trong một DataSet, cũng có những lúc cần phải thay đổi nó. Một ví dụ khá phổ biến đó là chọn dữ liệu từ một cơ sở dữ liệu, biểu diễ nó cho người dùng, và cập nhật cho cơ sở dữ liệu. Cập nhật với các Data Adapter Một SqlDataAdapter có thể bao gồm SelectCommand, một InsertCommand, UpdateCommand, và DeleteCommand. Giống như tên gọi, những đối tượng này là những thể hiện của SqlCommand (hoặc OleDbCommand dùng cho OleDbDataAdapter), vì vậy những câu lệnh này có thể chuyển thành SQL hoặc một stored procedure. Trong ví dụ này, tôi đã khôi phục lại các mã stored procedure từ phần Calling Stored Procedures để chèn, cập nhật, và xóa các mẫu tin Region. Mã có sẵn trong thư mục 12_DataAdapter2.
- Chèn một dòng mới Có hai cách để thêm một dòng mới vào một DataTable. Cách thứ nhât là gọi phương thức NewRow, để trả về một dòng trống sau đó định vị và thêm vào tập Rows như sau: DataRow r = ds.Tables["Region"].NewRow(); r["RegionID"]=999; r["RegionDescription"]="North West"; ds.Tables["Region"].Rows.Add(r); Cách thứ hai để thêm một dòng mới là truyền một mảng dữ liệu vào phương thức Rows.Add() giống như sau: DataRow r = ds.Tables["Region"].Rows.Add (new object [] { 999 , "North West" }); Mỗi dòng trong DataTable sẽ cài RowState là Added. Ví dụ sẽ xổ ra các mẫu tin trước khi nó thay đổi được cập nhật cho dữ liệu, vì vậy sau khi thêm các dòng sau vào DataTable, các dòng sẽ giống như sau. Chú ý rằng cột bên phải là trạng thái dòng. New row pending inserting into database 1 Eastern Unchanged 2 Western Unchanged 3 Northern Unchanged
- 4 Southern Unchanged 999 North West Added Để cập nhật cơ sở dữ liệu từ một DataAdapter, gọi phương thức Update() như sau đây: da.Update(ds , "Region"); Đối với một dòng mới trong DataTable, sẽ thực thi stored procedure và xuất ra các mẫu tìn trong DataTable một lần nữa. New row updated and new RegionID assigned by database 1 Eastern Unchanged 2 Western Unchanged 3 Northern Unchanged 4 Southern Unchanged 5 North West Unchanged Hãy nhìn dòng cuối của DataTable. Tôi đã nhập RegionID trong mã là 999, nhưng sau khi sẽ đổi RegionInsert stored procedure giá trị được đổi thành 5. Có sở dữ liệu thường tạo khoá chính cho bạn. SqlCommand aCommand = new SqlCommand("RegionInsert" , conn); aCommand.CommandType = CommandType.StoredProcedure; aCommand.Parameters.Add(new SqlParameter("@RegionDescription" , SqlDbType.NChar ,
- 50 , "RegionDescription")); aCommand.Parameters.Add(new SqlParameter("@RegionID" , SqlDbType.Int, 0, ParameterDirection.Output , false , 0, 0, "RegionID" , // Defines the SOURCE column DataRowVersion.Default , null)); aCommand.UpdatedRowSource = UpdateRowSource.OutputParameters; Chuyện gì sẽ xảy ra khi một data adapter phát các lệnh này, các tham số xuất sẽ được ánh xạ trở lại mã nguồn của dòng. Stored procedure có một tham số xuất ánh xạ trở lại DataRow. Giá trị của UpdateRowSource được cho trong bảng sau: Description UpdateRowSource Value
- Description UpdateRowSource Value Both Một stored procedure có thể trả về nhiều tham số xuất và cũng có thể là một cơ sở dữ liệu gồm các mẫu tin đã được cập nhật. FirstReturnedRecord Nó trả về một mẫu dữ liệu đơn, nội dung của mẫu tin đó có thể được trộn vào DataRow nguồn. Nó có có ích đối với một bảng có các cột mang giá trị mặc định hoặc tính toán, sau khi một câu lệnh INSERT chúng cần phải được đồng bộ với các DataRow trên máy trạm. Một ví dụ có thể là be 'INSERT (columns) INTO (table) WITH (primarykey)', sau đó là 'SELECT (columns) FROM (table) WHERE (primarykey)'. Các mẫu tin trả về có thể trộn vào tập các dòng. Tất cả dữ liệu trả về từ câu lệnh đều bị vứt bỏ. None OutputParameters Bất kì tham số xuât nào của câu lệnh đều được ánh xạ vào một cột thích hợp trong DataRow. Cập nhật một dòng đã có
- Cập nhật một dòng có sẵn trong DataTable chỉ là một trường hợp việc sử dụng bộ chỉ mục của lớp DataRow với tên của một cột hoặc số thứ tự của cột, giống như ví dụ sau đây: r["RegionDescription"]="North West England"; r[1] = "North East England"; Các hai câu lệnh đều cho cùng kết quả: Changed RegionID 5 description 1 Eastern Unchanged 2 Western Unchanged 3 Northern Unchanged 4 Southern Unchanged 5 North West England Modified Trong quá trính cập nhật cơ sở dữ liệu, trạng của dòng được cập nhật sẽ được gán là Modified. RowXóa một dòng Xóa một dòng là kết quả của việc gọi phương thức Delete(): r.Delete(); Một dòng được xóa có trạng thái là Deleted, nhưng bạn không thể đọc các cột từ một dòng đã xoá, nó không còn giá trị nữa. Khi gọi phương thức
- Update(), tất cả các dòng bị xoá sẽ sử dụng DeleteCommand, trong trường hợp này sẽ chạy stored procedure RegionDelete. Viết XML xuất Như bạn đã thấy, DataSet hỗ trợ mạnh việc định nghĩa sơ đồ của nó trong một XML, và bạn có thể đọc dữ liệu từ một tài liệu XML, bạn cũng có thể viết một tài liệu XML. Phương thức DataSet.WriteXml() cho phép bạn xuất các thành phần khác nhau của dữ liệu được lưu trong DataSet. Bạn có thể chọn chỉ xuất dữ liệu, hoặc dữ liệu và sơ đồ. Mã sau đây đưa ra một ví dụ của cho cả hai loại trên: ds.WriteXml(".\\WithoutSchema.xml"); ds.WriteXml(".\\WithSchema.xml" , XmlWriteMode.WriteSchema); File đầu tiên, WithoutSchema.xml được đưa ra dưới đây: 1 Eastern
- 2 Western 3 Northern 4 Southern File WithSchema.xml bao gồm cả sơ đồ và dữ liệu của DataSet:
- 1 Eastern
- 2 Western 3 Northern 4 Southern Chú ý rằng, các thuộc tính mở rộng cho các cột trong một DataSet, như AutoIncrement và AutoIncrementSeed - những thuộc tính này tương ứgn với các thuộc tính có thể định nghĩa trong một DataColumn.
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Khóa Hàm Thụ Visual Basic 6.0 Cơ sở dữ liệu (Database) Table, Record và Field
13 p | 335 | 141
-
Truy cập cơ sở dữ liệu qua C# ADO.NET - Phần 1
10 p | 301 | 107
-
Truy cập cơ sở dữ liệu qua C# ADO.NET phần 2
8 p | 246 | 91
-
Năm vấn đề chung về cơ sỡ dữ liệu trên PHP
10 p | 195 | 71
-
Bài giảng Lập trình Java cơ bản: Chương 7 - GV. Võ Hoàng Phương Dung
33 p | 143 | 29
-
Truy cập cơ sở dữ liệu với .NET - Làm việc với ADO.NET Phần cuối
13 p | 106 | 14
-
Truy cập dữ liệu qua C# ADO.NET
20 p | 105 | 13
-
Bài giảng Cơ sở dữ liệu: Chương 5 - Ngôn ngữ truy vấn SQL
0 p | 131 | 13
-
Bài giảng Cơ sở dữ liệu: Chương 4 - ThS. Nguyễn Thị Uyên Nhi
146 p | 55 | 10
-
Truy cập cơ sở dữ liệu qua C# ADO.NET
14 p | 107 | 9
-
Bài giảng Cơ sở dữ liệu: Chương 5 - ThS. Nguyễn Thị Khiêm Hòa (ĐH Ngân hàng TP.HCM)
28 p | 137 | 9
-
Bài giảng môn học Cơ sở dữ liệu - Chương 5: Ngôn ngữ truy vấn SQL
48 p | 103 | 7
-
Bài 7. Xuất bản cơ sở dữ liệu Win/ISIS trên Web sử dụng GenISIS như thế nào?
21 p | 79 | 6
-
Bài giảng Kết nối với MySQL và truy xuất cơ sở dữ liệu
34 p | 106 | 6
-
Bài giảng Cơ sở dữ liệu - Phần 4: Truy vấn (Query)
72 p | 47 | 6
-
Bài giảng Hệ quản trị Cơ sở dữ liệu - Bài 5: Truy xuất và hiệu chỉnh dữ liệu
106 p | 58 | 5
-
Bài giảng Cơ sở dữ liệu: Chương 3 - ThS. Trần Quang Hải Bằng
43 p | 95 | 4
-
Bài giảng Cơ sở dữ liệu: Chương 4 - Lê Nhị Lãm Thúy
36 p | 47 | 4
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn