1. Trang chủ
  2. » Công Nghệ Thông Tin

Đề cương bài giảng môn Thực tập cơ sở dữ liệu

67 20 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 67
Dung lượng 1,34 MB

Nội dung

Đề cương bài giảng môn Thực tập cơ sở dữ liệu được biên soạn với các nội dung thực hành làm quen và sử dụng được hệ quản trị cơ sở dữ liệu SQL Server; thực hành làm quen và sử dụng được hệ quản trị cơ sở dữ liệu SQL Server; hành làm quen và sử dụng được hệ quản trị cơ sở dữ liệu SQL Server...

BỘ MƠN DUYỆT Chủ nhiệm Bộ mơn ĐỀ CƯƠNG CHI TIẾT BÀI GIẢNG (Dùng cho 15 tuần thực hành) Học phần: THỰC TẬP CƠ SỞ DỮ LIỆU Bộ môn: Hệ thống thông tin Khoa: Công nghệ thông tin Thay mặt nhóm mơn học Đỗ Thị Mai Hường Hoa Tất Thắng Thơng tin nhóm mơn học TT Họ tên giáo viên Học hàm Học vị Đơn vị công tác (Bộ môn) Đỗ Thị Mai Hường GVC ThS Hệ thống thông tin Chu Thị Hường GVC ThS Hệ thống thông tin Địa điểm làm việc: Bộ môn Hệ thống thông tin - Khoa Công nghệ thông tin Điện thoại, email: Đỗ Thị Mai Hường: 0983366922, email: dohuong@gmail.com Tuần Bài thực hành số 1: Thực hành làm quen sử dụng hệ quản trị sở liệu SQL Server Mục đích: Giúp sinh viên làm quen sử dụng hệ quản trị sở liệu SQL Server Yêu cầu: Tạo sở liệu, tạo bảng, nhập liệu vào bảng (Sinh viên đọc tài liệu tham khảo Giáo trình SQL Server từ trang 6-71, slide giảng Chương2_Mơ hình liên kết thực thể, mơ hình quan hệ, chương 5_Hệ quản trị SQL Server) - Hình thức tổ chức dạy học: Thực hành - Thời gian: 6-12t - Địa điểm: Phòng máy K12 - Nội dung chính: I Tóm tắt lý thuyết: Tạo sở liệu Theo lý thuyết sở liệu, trước tạo CSDL ta phải thực phân tích thơng tin liên quan mục đích sử dụng CSDL cho ài tốn mình: Tên CSDL, table, ràng buộc,… tuân theo chuẩn CSDL (phần bàn kỹ sau) Tạo theo công cụ: - Vào Enterprise Manager -> Databases - Nhấn nút phải chuột/hoặc menu Action -> New Database… Tạo bảng liệu: Table (bảng liệu) thành phần CSDL, CSDL thiết kế từ nhiều bảng liệu, bảng liệu cấu trúc từ hàng cột liệu, hàng dùng mô tả đối tượng, vấn đề, kiện, cột thể thuộc tính đối tượng, kiện, hàng Dữ liệu cột có kiểu (data type) Ngồi hàng, cột bảng cịn có khóa, liên kết, ràng buộc, Trước bắt tay vào thiết lập bảng liệu trước hết ta phải xác định xem bảng xây dựng nào, dựa số thông tin sau: - Kiểu liệu bảng - Các cột, kiểu liệu tương ứng (và độ dài cần thiết) - Cột cho phép giá trị NULL (là giá trị mà phần liệu thuộc hàng, cột xác định không gán giá trị nào, nên phần tử có giá trị NULL không nhau) - Giá trị ngầm định (là giá trị mà chưa nhập vào nhận giá trị này) - Chỉ số Index, khóa chính, khóa ngồi Kiểu liệu SQL Server gồm kiểu liệu sau:  Integers  Bigint: bytes  Int: bytes  Smallint: bytes  Tinyint: byte, từ -> 255  bit  Bit: value  decimal and numeric  Decimal từ -10^38+1->10^38 –1  Numeric: giống decimal  money and smallmoney  Money: bytes  Smallmoney: bytes  Approximate Numerics  Float: từ -1.79E + 308 -> 1.79E + 308  Real: từ -3.40E + 38 -> 3.40E + 38  datetime and smalldatetime  Datetime: từ 1/1/1753-> 31/12/9999  Smalldatetime từ 1/1/1900, -> 6/6/2079  Character Strings  Char: Fixed-length non-Unicode character, chọn Design Table - Thực sửa cấu trúc bảng Xóa bảng Sử dụng công cụ - Chọn bảng - Nhất chuột phải - Chọn Delete -> Yes Bảng liệu có tham gia mối quan hệ Relationship xóa bạn cần ý: Nếu bảng chứa khóa ngồi việc xóa thực bình thường, bảng chứa khóa mối quan hệ khơng xóa Nhập liệu vào bảng Sử dụng công cụ - Chọn bảng liệu - Nhất chuột phải -> Open Table II Bài thực hành: Bài 1: Sinh viên sử dụng công cụ SQL Server để thực hiện: Tạo sở liệu QUANLYNHANSU Tạo bảng Nhanvien Donvi với cấu trúc trường hình Nhập liệu cho bảng này: ghi cho bảng Donvi 10 ghi cho bảng nhân viên Bài 2: Sinh viên tạo cấu trúc bảng sơ đồ bên Nhập liệu cho bảng Tuần Bài thực hành số 2: Thực hành làm quen sử dụng hệ quản trị sở liệu SQL Server Mục đích: Giúp sinh viên làm quen sử dụng hệ quản trị sở liệu SQL Server Yêu cầu: Sinh viên làm việc theo nhóm: Lựa chọn đề tài, mơ tả tốn, xây dựng mơ hình liên kết thực thể, chuyển đổi sang mơ hình quan hệ Tạo sở liệu, tạo bảng, nhập liệu vào bảng (Sinh viên đọc tài liệu tham khảo Giáo trình SQL Server từ trang 6-71, slide giảng Chương2_Mơ hình liên kết thực thể, mơ hình quan hệ, chương 5_Hệ quản trị SQL Server) - Hình thức tổ chức dạy học: Thực hành - Thời gian: 6-12t - Địa điểm: Phòng máy K12 - Nội dung chính: I Tóm tắt lý thuyết: Mơ hình liên kết thực thể (ER): – mơ hình liệu mức quan niệm, mơ hình hóa liệu mối quan hệ đối tượng giới thực, tập trung vào cấu trúc liệu ràng buộc – mơ hình trung gian để chuyển yêu cầu quản lý liệu giới thực thành mơ hình CSDL quan hệ Thực Thể (entity) Thực thể vật tồn phân biệt được, chẳng hạn sinh viên Nguyễn Văn Thành, lớp Cao Đẳng Tin Học 2A, môn học CơSởDữLiệu thực thể Thuộc tính (attribute) Các đặc điểm riêng thực thể gọi thuộc tính Chẳng hạn thuộc tính sinh viên Nguyễn Văn Thành là:mã số sinh viên, giới tính, ngày sinh, hộ thường trú, lớp theo học, … Loại thực thể(entity type) Là tập hợp thực thể có thuộc tính Mỗi loại thực thể phải đặt tên cho có ý nghĩa Một loại thực thể biểu diễn hình chữ nhật • Loại thuộc tính – Thuộc tính đơn – khơng thể tách nhỏ – Thuộc tính phức hợp – tách thành thành phần nhỏ • Loại giá trị thuộc tính – Đơn trị: thuộc tính có giá trị cho thực thể (VD: số • • CMND, …) – Đa trị: thuộc tính có tập giá trị cho thực thể (VD: cấp, …) – Suy diễn (năm sinh   tuổi) Quan hệ(liên kết): Là liên kết hay nhiều tập thực thể Ví dụ tập thực thể NHANVIEN PHONGBAN có liên kết – Một nhân viên thuộc phịng ban – Một phịng ban có nhân viên làm trưởng phịng Các kí hiệu mơ hình liên kết thực thể: Mối liên kết ke Loại thực thể R E1 Loại thực thể yếu N E2 (min,max) Thuộc tính khóa Thuộc tính đơn Thuộc tính đa trị E R TT tách TT tách TT tách Thuộc tính phức Mơ hình quan hệ: Mơ hình quan hệ biểu thị sở liệu tập quan hệ Mỗi quan hệ biểu diễn bảng giá trị, dòng bảng biểu thị tấp hợp giá trị liệu liên quan với • Quan hệ gồm – Tên – Tập hợp cột • • Cố định • Được đặt tên • Có kiểu liệu – Tập hợp dịng • Thay đổi theo thời gian Một dịng ~ Một thực thể • Quan hệ ~ Tập thực thể Thuộc tính: • • • Tên cột quan hệ Mô tả ý nghĩa cho giá trị cột Tất liệu cột có kiểu liệu • Lược đồ quan hệ – Tên quan hệ – Tên tập thuộc tính • Lược đồ CSDL – Gồm nhiều lược đồ quan hệ • Bộ: • Là dịng quan hệ (trừ dịng tiêu đề - tên thuộc tính) • Thể liệu cụ thể thuộc tính quan hệ Quy tắc chuyển đổi từ mơ hình liên kết thực thể sang mơ hình quan hệ Tên thực thể chuyển thành tên quan hệ Tên thuộc tính chuyển thành tên thuộc tính quan hệ Thuộc tính khóa chuyển thành khóa quan hệ • Quy tắc 1: Với kiểu liên kết 1:1 – Cách 1: Chuyển khóa LĐQH sang làm khóa ngoại LĐQH ngược lại – Cách 2: Nhập kiểu thực thể mối liên kết thành LĐQH, chọn khóa cho phù hợp • Quy tắc 2: Với kiểu liên kết 1:n Chuyển khóa LĐQH bên (cha) sang làm khóa ngoại LĐQH bên nhiều (con) • Quy tắc 3: Với kiểu liên kết n:n Chuyển mối liên kết thành LĐQH có thuộc tính thuộc tính mối liên kết, thêm thuộc tính khóa LĐQH có liên quan, khóa LĐQH thuộc tính thêm vào • Quy tắc 4: Thực thể yếu Chuyển thành quan hệ o Có tên với thực thể yếu o Thêm vào thuộc tính khóa quan hệ liên quan II Bài thực hành: Bài 1: Chuyển đổi mơ hình liên kết thực thể cho bên sang mơ hình quan hệ cài đặt mơ hình liệu thu hệ quản trị SQL Server ( Thao tác công cụ: Sửa lại cấu trúc sở liệu thực thực hành 1) 10 - Thời gian: 6-12t - Địa điểm: Phòng máy K12 - Nội dung chính: I Tóm tắt lý thuyết: PHẦN KẾT NỐI CƠ SỞ DỮ LIỆU TRONG C# -Bước 1: xác định chuỗi kết nối câu lệnh SQL cần thực connStr = @”Data Source=WINDWALK-PC\SQLEXPRESS;Initial Catalog=datagridviewdemo;User ID=sa;password=123456”; // chuỗi kết nối đến CSDL connStr=@"Data Source=(local);Initial Catalog=THUCHANH;Integrated Security=True" String sql = “select * from Table”// câu lệnh select cần thực -Bước 2: tạo đối tượng connection kết nối ứng dụng CSDL SqlConnection conn = new SqlConnection(); // khởi tạo đối tượng kết nối Conn.ConnectionString = connStr; // lấy đường dẫn đến sở liệu Conn.Open(); // mở kết nối -Bước : tạo đối tượng SqlAdapter cầu nối dataset datasource để thực công việc đọc hay cập nhật liệu SqlDataAdapter da = new SqlDataAdapter(sql,conn) ; Bước :dữ liệu đọc từ câu lệnh select lưu vào datatable dataset DataTable dt = new DataTable() ; // khởi tạo đối tượng datatable da.Fill(dt) ; // fill aliệu vào datatable 53 Bước 5: liệu hiển thị datagridview Ta cần DataView kết nối đến DataTable Đối tượng DataView dùng cho việc xếp,lọc, tìm kiếm… DataView dv = new DataView(dt); Bước 6: hiển thị liệu lên datagridview Dgr.DataSource = dv; // gán datasource cho datagridview Dgr.AutoResizeColums(); // chỉnh lại chiều rộng cột datagridview Bước 7: Đóng kết nối conn.close(); PHẦN SỬ DỤNG STORED PROCEDURE TRONG C# Thiết lập đối tượng SqlCommand để sử dụng stored procedure, biết cách dùng parameter với stored procedure Thay tạo truy vấn động mã nguồn chương trình, ta lợi ích việc tái sử dụng hiệu suất sử dụng stored procedure Thực thi Stored Procedure Ngoài việc tạo chuỗi lệnh SQL, ta phải thiết lập SqlCommand để thực thi stored procedure Có hai bước để làm điều này: cho đối tượng SqlCommand biết stored procedure thực thi thiết lập chế độ thực thi stored procedure cho SqlCommand Hai bước minh họa đoạn mã sau: 54 // create a command object identifying the stored procedure SqlCommand cmd = new SqlCommand(" Stored Procedure Name", conn); // set the command object so it knows to execute a stored procedure cmd.CommandType = CommandType.StoredProcedure; Khi khai báo đối tượng SqlCommand trên, tham số gán “Stored Procedure Name” Đây tên stored procedure database SQL Server Tham số thứ hai đối tượng connection, tương tự constructor SqlCommand dùng để thực thi câu truy vấn Dòng lệnh thứ hai cho đối tượng SqlCommand kiểu lệnh thực thi cách gán propertyCommandType thành giá trị StoredProcedure CommandType Bằng cách thay đổi property CommandType này, SqlCommand hiểu chuỗi lệnh tham số thứ stored procedure Phần lại đoạn mã viết tương tự trước Truyền Parameter cho Stored Procedure Dùng parameter cho stored procedure tương tự dùng cho chuỗi lệnh truy vấn Đoạn code sau cho thấy cách làm điều này: // create a command object identifying the stored procedure SqlCommand cmd = new SqlCommand("CustOrderHist", conn); // set the command object so it knows to execute a stored procedure cmd.CommandType = CommandType.StoredProcedure; // add parameter to command, which will be passed to the stored procedure cmd.Parameters.Add(new SqlParameter("@CustomerID", custId)); Constructor SqlCommand xác định tên stored procedure, CustOrderHist, tham số Stored procedure nhận tham số, tên @CustomerID Do đó, ta phải tạo parameter cách dùng đối tượng SqlParameter Tên parameter truyền tham số SqlParameter constructor phải giống với tên tham số stored procedure Sau thực thi command giống với đối tượng SqlCommand khác 55 Một ví dụ hồn chỉnh Mã lênh Listing chứa ví dụ hồn chỉnh minh họa cách dùng stored procedure Có phương thức tách riêng cho stored procedure không tham số cho stored procedure có tham số Listing 1: Executing Stored Procedures using System; using System.Data; using System.Data.SqlClient; class StoredProcDemo { static void Main() { StoredProcDemo spd = new StoredProcDemo(); // run a simple stored procedure spd.RunStoredProc(); // run a stored procedure that takes a parameter spd.RunStoredProcParams(); } // run a simple stored procedure public void RunStoredProc() { SqlConnection conn = null; SqlDataReader rdr = null; Console.WriteLine("\nTop 10 Most Expensive Products:\n"); try 56 { // create and open a connection object conn = new SqlConnection("Server=(local);DataBase=Northwind;Integrated Security=SSPI"); conn.Open(); // create a command object identifying the stored procedure SqlCommand cmd = new SqlCommand("Ten Most Expensive Products", conn); // set the command object so it knows to execute a stored procedure cmd.CommandType = CommandType.StoredProcedure; // execute the command rdr = cmd.ExecuteReader(); // iterate through results, printing each to console while (rdr.Read()) { Console.WriteLine( "Product: {0,-25} Price: ${1,6:####.00}", rdr["TenMostExpensiveProducts"], rdr["UnitPrice"]); } } finally { if (conn != null) { conn.Close(); 57 } if (rdr != null) { rdr.Close(); } } } // run a stored procedure that takes a parameter public void RunStoredProcParams() { SqlConnection conn = null; SqlDataReader rdr = null; // typically obtained from user // input, but we take a short cut string custId = "FURIB"; Console.WriteLine("\nCustomer Order History:\n"); try { // create and open a connection object conn = new SqlConnection("Server=(local);DataBase=Northwind;Integrated Security=SSPI"); conn.Open(); // create a command object identifying the stored procedure SqlCommand cmd = new SqlCommand( "CustOrderHist", conn); 58 // set the command object so it knows to execute a stored procedure cmd.CommandType = CommandType.StoredProcedure; // add parameter to command, which will be passed to the stored procedure cmd.Parameters.Add( new SqlParameter("@CustomerID", custId)); // execute the command rdr = cmd.ExecuteReader(); // iterate through results, printing each to console while (rdr.Read()) { Console.WriteLine( "Product: {0,-35} Total: {1,2}", rdr["ProductName"], rdr["Total"]); } } finally { if (conn != null) { conn.Close(); } if (rdr != null) { rdr.Close(); } 59 } } } Phương thức RunStoredProc() Listing đơn giản chạy stored procedure in kết console Trong phương thức RunStoredProcParams(), stored procedure nhận tham số Điều cho thấy khơng có khác biệt việc dùng tham số với chuỗi truy vấn stored procedure Tổng kết Để thực thi stored procedure, ta cần tên stored procedure tham số SqlCommand constructor sau gán property CommandType SqlCommand thành StoredProcedured Ta truyền tham số cho stored procedure cách dùng đối tượng SqlParameter, tương tự cách làm với đối tượng SqlCommand dùng để thực thi câu truy vấn II Bài thực hành Bài 1: Sinh viên làm theo ví dụ minh họa: Để giảm thiểu việc viết lệnh T-SQL mã code C#, người ta tạo thủ tục Hệ quản trị CSDL Với cách ta dễ dàng bảo trì mã T-SQL Code C# trở lên ngắn gọn Đặc biệt ta phải thực thi thủ tục lên đến hàng trang giấy hay vài trang giấy thực thi thủ tục giải pháp hữu hiệu lập trình với ADO.NET Giả sử, ta sử dụng CSDL SQL Server có tên HRM, có bảng đơn giản là: Departments Bước 1: Thiết kế CSDL với bảng Departments Create table Departments(DepartmentID int primary key,DepartmentName nvarchar(250),Description nvarchar(250) Lưu ý: Trường DepartmentID thiết lập khóa chính, tự động tăng Bước 2: Viết thủ tục cho phép thêm, sửa, xóa phịng ban /* Thủ tục thêm phòng ban*/ 60 CREATE PROC [dbo].[SP_InsertDepartment] ( @Name nvarchar(250), @Description nvarchar(250) ) AS INSERT INTO Departments VALUES(@Name,@Description); /* Thủ xóa phòng ban*/ CREATE PROC [dbo].[SP_DeleteDepartment] ( @ID int ) AS DELETE Departments WHERE DepartmentID= @ID; /* Thủ tục sửa thơng tin phịng ban*/ CREATE PROC [dbo].[SP_UpdateDepartment] ( @ID int, @Name nvarchar(250), @Description nvarchar(250) ) AS UPDATE Departments SET DepartmentName = @Name, Description = @Description WHERE DepartmentID= @ID; Bước 3: Bây ta cần thiết kế giao diện sau: 61 Trong ví dụ ta ràng buộc liệu DataGridView với trường: DepartmentID, DepartmentName, Description Tuy nhiên cột Mã phòng ban ẩn cách cho thuộc tính Visible cột = False Tại lại ẩn đi? Nhằm suốt với người dùng, trường tự động tăng nên người dùng không cần nhập, không cần quan tâm, lại trường mà người lập trình cần thiết kế để thuận tiện thao tác cập nhật Sau bổ sung vào giao diện ô TextBox (txtName txtDescripton), Button: btnAdd, btnUpdate, btnDelete Ta giao diện hình sau: Bước 4: Lập trình hiển thị liệu lên DataGridView Đầu tiên ta khai báo khởi tạo đối tượng Connection Sau ta viết hàm LoadData() dùng để load liệu lên DataGridView hàm cịn sử dụng lại ta thêm, sửa, xóa ghi Viết code sau: 62 string strConn = @"Server=.\SQLEXPRESS; Database=HRM; Integrated Security=True"; SqlConnection conn; private void LoadData() { SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Departments", conn); DataTable dt = new DataTable(); da.Fill(dt); dgvDeparts.DataSource = dt; } private void frmDepartment_Load(object sender, EventArgs e) { conn = new SqlConnection(strConn); conn.Open(); LoadData(); } Khi viết xong đoạn lệnh trên, chạy chương trình kết hiển thị cột STT trống khơng có ràng buộc với trường Bởi ta viết kiện RowPrePaint điều khiển DataGridView sau: private void dgvDeparts_RowPrePaint(object sender, DataGridViewRowPrePaintEventArgs e) { dgvDeparts.Rows[e.RowIndex].Cells["clNo"].Value = e.RowIndex + 1; } Lúc cột số thứ tự điền số tự động mong muốn 63 Hãy chuyển sang bước Bước 5: Hiển thị liệu lên TextBox tương ứng chọn dòng DataGridView private void dgvDeparts_CellClick(object sender, DataGridViewCellEventArgs e) { if (e.RowIndex >= && e.ColumnIndex >= 0) { txtName.Text = Convert.ToString(dgvDeparts.CurrentRow.Cells["clName"].Value); txtDescription.Text = Convert.ToString(dgvDeparts.CurrentRow.Cells["clDescription"].Value); } } Bước 6: Thực thi thủ tục thêm phòng ban: SP_InsertDepartment private void btnAdd_Click(object sender, EventArgs e) { // Khai báo khởi tạo đối tượng Command, truyền vào tên thủ tục tương ứng SqlCommand cmd = new SqlCommand("SP_InsertDepartment",conn); 64 // Khai báo kiểu thực thi Thực thi thủ tục cmd.CommandType = CommandType.StoredProcedure; // Khai báo gán giá trị cho tham số đầu vào thủ tục // Khai báo tham số thứ @Name - tên tham số tạo thủ tục SqlParameter p = new SqlParameter("@Name", txtName.Text); cmd.Parameters.Add(p); // Khởi tạo tham số thứ thủ tục @Description p = new SqlParameter("@Description",txtDescription.Text); cmd.Parameters.Add(p); // Thực thi thủ tục int count = cmd.ExecuteNonQuery(); if (count > 0) { MessageBox.Show("Thêm thành công"); LoadData(); } else MessageBox.Show("Khơng thể thêm mới"); } Có thể chạy chương trình thử nghệm! Bước 7: Tương tự cho việc thực thi thủ tục sửa xóa sau: private void btnUpdate_Click(object sender, EventArgs e) { SqlCommand cmd = new SqlCommand("SP_UpdateDepartment", conn); cmd.CommandType = CommandType.StoredProcedure; int id = (int)dgvDeparts.CurrentRow.Cells["clID"].Value; SqlParameter p = new SqlParameter("@ID", id); cmd.Parameters.Add(p); 65 p = new SqlParameter("@Name", txtName.Text); cmd.Parameters.Add(p); p = new SqlParameter("@Description", txtDescription.Text); cmd.Parameters.Add(p); int count = cmd.ExecuteNonQuery(); if (count > 0) { MessageBox.Show("Sửa thành công!"); LoadData(); } else MessageBox.Show("Không sửa được!"); } private void btnDelete_Click(object sender, EventArgs e) { if (MessageBox.Show("Bạn có chắn mn xóa ghi chọn khơng?", "Thông báo", M DialogResult.Yes) { SqlCommand cmd = new SqlCommand("SP_DeleteDepartment", conn); cmd.CommandType = CommandType.StoredProcedure; int id = (int)dgvDeparts.CurrentRow.Cells["clID"].Value; SqlParameter p = new SqlParameter("@ID", id); cmd.Parameters.Add(p); int count = cmd.ExecuteNonQuery(); if (count > 0) { MessageBox.Show("Xóa thành cơng!"); 66 LoadData(); } else MessageBox.Show("Khơng thể xóa ghi thời!"); } } Bài 2: Sinh viên làm tập xây dựng ứng dụng tập nhóm 67 ... thủ tục tạo ra, thực hai yêu cầu qua lời gọi thủ tục: sp_LenDanhSachDiem 'CST006', 'Cơ sở liệu' ,5,'CNTT' II Bài thực hành Bài 1: Thực hành với sở liệu Quản lý đề án công ty Thêm đề án vào bảng... END II Bài thực hành Bài 1: Thực hành với sở liệu Quản lý đề án công ty Tạo hàm thống kê số lượng đề án theo phòng ban Tạo hàm thống kê số lượng nhân viên tham gia đề án theo đề án Bài 2: Thực. .. này, ta thu kết quả: Bài 2: Sinh viên thao tác với sở liệu quản lý đề án công ty, thực yêu cầu với hàm gom nhóm kết hợp 31 Bài 3: Thực hành theo đề tài nhóm Thực truy vấn liệu với hàm gom nhóm,

Ngày đăng: 07/05/2021, 13:38

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN