[原创]域更新函数
时 间:2009-01-18 11:17:40
作 者:郑家龙 ID:90 城市:上海
摘 要:[原创]域更新函数
正 文:
'--------------------------------------------------------------------------------------------------------------
'名称: 域更新函数
'功能: 同Dlookup等域函数
'参数:
' 同Dlookup等域函数,但Expr参数有点像Switch,以便更新多少字段.
' cn参数可以用来?行事??理
'用法:
' 1.先决条件:假如有表[BMB],且含有字段luoma,Int,ddate,check,mony
' 2.debug.Print DSet("luoma,aa,Int,3455,ddate,2009-9-9,check,-1,mony,5000 ","BMB","id=0")
'返回: True表示成功,False表示未成功或没有更新
'日期: 2007-07-26
'改正: 2007-07-26
'版本: 1.01
'作者: zhengjialon
'--------------------------------------------------------------------------------------------------------------
Public Function DSet(Expr As String, Domain As String, Optional Criteria As String, Optional cn As ADODB.Connection) As Boolean
On Error GoTo lblErr:
Dim i As Integer, l As Integer
Dim ExprS As Variant
Dim rst As New ADODB.Recordset
ExprS = Split(Expr, ",")
l = UBound(ExprS)
rst.Open "Select " & "*" & " From " & Domain & IIf(Trim(Criteria) <> "", " Where " & Criteria, ""), CurrentProject.Connection, adOpenStatic, adLockOptimistic, adCmdText
If Not rst.EOF Then
For i = 0 To l - 1 Step 2
Select Case rst(ExprS(i)).Type
Case adChar 'String
rst(ExprS(i)) = IIf(ExprS(i + 1) = "", Null, ExprS(i + 1))
Case adBoolean '
rst(ExprS(i)) = IIf(Trim(ExprS(i + 1)) = "" Or Trim(ExprS(i + 1)) = False Or Trim(ExprS(i + 1)) = 0, False, True)
Case Else
rst(ExprS(i)) = IIf(Trim(ExprS(i + 1)) = "", Null, ExprS(i + 1))
End Select
Next i
rst.Update
DSet = True
End If
rst.Close
Set rst = Nothing
lblExit:
Exit Function
lblErr:
If Err.Number = 3265 Then 'FieldName Is Noting
MsgBox "FieldName: [" & ExprS(i) & "] Is Noting ! ", vbCritical
ElseIf Err.Number = -2147352571 Then 'FieldValue <> FieldType Tip
MsgBox "FieldValue: [" & ExprS(i + 1) & "] Is Error ! ", vbCritical
Else 'ohter error
MsgBox Err.Number & Err.Description
End If
End Function
'增加了更多容错处理
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 通过命令按钮让Access列表...(04.24)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)

学习心得
最新文章
- 仓库管理实战课程(15)-月度库存...(04.30)
- Access选择打印机、横纵向、纸...(04.29)
- 仓库管理实战课程(14)-出库功能...(04.26)
- 通过命令按钮让Access列表框指...(04.24)
- 仓库管理实战课程(13)-入库功能...(04.21)
- Access控件美化之--美化按钮...(04.19)
- Access多行文本按指定字符筛选...(04.18)
- Microsoft Access数...(04.18)
- 仓库管理实战课程(12)-月度结存...(04.16)
- 仓库管理实战课程(11)-人性化操...(04.15)