Office中国论坛/Access中国论坛

标题: SQL SERVER里自定义函数怎么做? [打印本页]

作者: zhenghu    时间: 2005-12-1 23:37
标题: SQL SERVER里自定义函数怎么做?
在mdb里有一个自定义函数,到SQL server里该怎么解决?

Function proj() As String
If IsNull([Forms]![采0:工程]![com工程]) Then
proj ="全部"

Else
proj = [Forms]![采0:工程]![com工程]
End If
End Function


[此贴子已经被作者于2005-12-1 15:37:43编辑过]


作者: tz-chf    时间: 2005-12-2 05:59
不是一样嘛

sql和access里的函数两码事
作者: zhenghu    时间: 2005-12-2 16:04
我的意思是这个函数怎么转换到SQL SERVER里的自定义函数.因为在视图里我要用这个函数.
作者: tz-chf    时间: 2005-12-2 17:03
查一下SQL的联机丛书。

你调用视图的时候怎么把函数里的参数传给它呢?
作者: eyewitnes    时间: 2005-12-20 23:39
以下是引用zhenghu在2005-12-1 15:37:00的发言:


在mdb里有一个自定义函数,到SQL server里该怎么解决?

Function proj() As String
If IsNull([Forms]![采0:工程]![com工程]) Then
proj ="全部"

Else
proj = [Forms]![采0:工程]![com工程]
End If
End Function

这段代码在MDB中可以用 proj =NZ([Forms]![采0:工程]![com工程]) ,"全部") 代替

在ADP中将NZ改为ISNULL
作者: zyp    时间: 2005-12-20 23:52
SQL中根本无法直接调用ACCESS窗体中的控件,但可以在VBA执行存储过程来实现

在存储过程中建一个参数变量(赋默认值NULL,即可选参数),在VBA中检测[Forms]![采0:工程]![com工程]是否为空,为空时不给参数赋值,不为空时赋"全部"或其它任意值,只要不为null即可.

然后再在存储过程中针对那个变量进行判断




欢迎光临 Office中国论坛/Access中国论坛 (http://www.office-cn.net/) Powered by Discuz! X3.3