Access中使用DAO和ADO进行数据处理的区别
1个回答
展开全部
ADO和DAO都是操作数据表的方法。此两者即有相同又有不同:
ADO(ACTIVEX DATA OBJECTS)应用层的数据访问接口 ,DAO (DATA ACCESS OBJECTS) 对象的数据访问接口 ,也就是说ADO是它使用OLEDB接口胡绝让而不是ODBC,DAO是access的产物,而ADO即应用在多种语言。
新增事件
Dim rst As ADODB.Recordset 定义ADO记录集
Dim strSQL As String 定义strsql,在下面要用到,具体用时,具体定义。
……….
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.AddNew 注:新增,修改为edit,删除为delete
……..
rst.Update 注:新增与修改都需要更新记录集,删除与加载宏备则不需要这句。
rst.Close
Set rst = Nothing
新增事件
Dim rst As DAO.Recordset 定义DAO记录集
Dim strSQL As String
……
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.AddNew
……..
rst.Update
rst.Close
Set rst = Nothing
加载事件
Dim rst As ADODB.Recordset 定义ADO记录集
…….
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst 移裤局动到第一条
…..
rst.Close
Set rst = Nothing
加载事件
Dim rst As DAO.Recordset 定义DAO记录集
……..
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
…….
rst.Close
Set rst = Nothing
修改事件
Dim rst As ADODB.Recordset 定义ADO记录集
……
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst
rst.EditMode
…….
rst.Update
rst.Close
Set rst = Nothing
修改事件
Dim rst As DAO.Recordset 定义DAO记录集
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
rst.Edit
……
rst.Update
rst.Close
Set rst = Nothing
删除事件
Dim rst As ADODB.Recordset 定义ADO记录集
……..
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst
rst.Delete '删除
rst.Close
Set rst = Nothing
删除事件
Dim rst As DAO.Recordset 定义DAO记录集
……..
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
rst.Delete '删除
rst.Close
Set rst = Nothing
ADO(ACTIVEX DATA OBJECTS)应用层的数据访问接口 ,DAO (DATA ACCESS OBJECTS) 对象的数据访问接口 ,也就是说ADO是它使用OLEDB接口胡绝让而不是ODBC,DAO是access的产物,而ADO即应用在多种语言。
新增事件
Dim rst As ADODB.Recordset 定义ADO记录集
Dim strSQL As String 定义strsql,在下面要用到,具体用时,具体定义。
……….
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.AddNew 注:新增,修改为edit,删除为delete
……..
rst.Update 注:新增与修改都需要更新记录集,删除与加载宏备则不需要这句。
rst.Close
Set rst = Nothing
新增事件
Dim rst As DAO.Recordset 定义DAO记录集
Dim strSQL As String
……
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.AddNew
……..
rst.Update
rst.Close
Set rst = Nothing
加载事件
Dim rst As ADODB.Recordset 定义ADO记录集
…….
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst 移裤局动到第一条
…..
rst.Close
Set rst = Nothing
加载事件
Dim rst As DAO.Recordset 定义DAO记录集
……..
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
…….
rst.Close
Set rst = Nothing
修改事件
Dim rst As ADODB.Recordset 定义ADO记录集
……
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst
rst.EditMode
…….
rst.Update
rst.Close
Set rst = Nothing
修改事件
Dim rst As DAO.Recordset 定义DAO记录集
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
rst.Edit
……
rst.Update
rst.Close
Set rst = Nothing
删除事件
Dim rst As ADODB.Recordset 定义ADO记录集
……..
Set rst = New ADODB.Recordset
rst.CursorLocation = adUseClient
rst.Open strSQL, CurrentProject.Connection, 2, 3
rst.MoveFirst
rst.Delete '删除
rst.Close
Set rst = Nothing
删除事件
Dim rst As DAO.Recordset 定义DAO记录集
……..
Set rst = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
rst.MoveFirst
rst.Delete '删除
rst.Close
Set rst = Nothing
威孚半导体技术
2024-08-19 广告
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层...
点击进入详情页
本回答由威孚半导体技术提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询