Em muốn tự khi lưu dữ liệu ngày đầu tiên của năm mới, thì table từ 3 năm về trước sẽ tự động bị xoá đi. Cụ thể: ngày 01/01/2010, em lưu dữ liệu thì table lưu dữ liệu của 2007 bị xoá đi.
Đồng thời, em muốn xoá table với điều kiện nó tồn tại: Cụ thể: câu lệnh để thực hiện:
Nếu tableA có trong MDB thì xoá tableA
Các bác cho em xin đoạn code nhé
Đáp:
Mình gửi bạn 1 đoạn code xóa table:
Code:
Sub DelTable(T As String) DoCmd.DeleteObject acTable, T End Sub
Ở đây bạn khai báo table nào thuộc năm nào.
sau đó có thể gọi 1 sub xóa table cũ hơn 3 năm:
Code:
sub DelTable3yearOld() Dim Db As Database, Rs As Recordset, sql1 as string SQL1="select TableName from tblTableInfo where (year(date())-year(TableDate))>=3 Set Db = CurrentDb() Set Rs = Db.OpenRecordset(SQL) Do Until rs.EOF Deltable rs(0) rs.MoveNext Loop Rs.Close set DB = Nothing End Sub
Nhớ lưu trước khi thử nghiệm nhé
Không có nhận xét nào:
Đăng nhận xét
» Hãy để lại tên, email của bạn khi bạn post comment, để mình có thể dễ dàng trả lời comment của bạn khi cần.
» Có thể sử dụng các thẻ < b>,< i>,< a>. Và các icon thông dụng trên YM