栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用ADO和VB将NULL或空字符串传递给存储过程输入参数?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用ADO和VB将NULL或空字符串传递给存储过程输入参数?

这里的快速测试表明NULL应该可以完成这项工作。我用来测试的示例代码(带有一个按钮和一个文本框的简单表单):

Private Sub Command1_Click()    Dim dbConn As ADODB.Connection    Dim dbComm As ADODB.Command    Dim dbRS As ADODB.Recordset    Set dbConn = New ADODB.Connection    With dbConn        .ConnectionString = "...REPLACE THIS ACCORDINGLY..."        .ConnectionTimeout = 10        .Open    End With    Set dbComm = New ADODB.Command    With dbComm        .ActiveConnection = dbConn        .CommandType = adCmdStoredProc        .CommandText = "usp_Bob"        .Parameters.Append .CreateParameter("b", adVarChar, adParamInput, 10, Null)        Set dbRS = .Execute    End With    Text1.Text = dbRS.Fields.Item(0).Value    dbRS.Close    dbConn.CloseEnd Sub

它调用了这个存储过程:

ALTER PROCEDURE usp_Bob @b VARCHAr(10)AS IF @b IS NULL  SELECT 'NULL' AS '1' ELSE  IF @b = ''   SELECT 'EMPTY' AS '1'  ELSE   SELECT 'NOT NULL AND NOT EMPTY' AS '1'

usp_Bob使用VB值返回“ NULL”

Null
(根据上面的示例),使用VB值返回“ NOT NULL”
vbNull
。如果
Null
对您不起作用,那么我无法对可能出问题的地方发表评论……!

类似地,应该以空字符串的形式传递空字符串(即空字符串),即

str = ""
usp_Bob返回“ EMPTY”。其他任何东西都会返回“ NOT NULLAND NOT EMPTY”(如预期)。

如果您无法传递NULL,则另一种选择是在sproc中将一个空字符串转换为NULL,即

IF @param = ''    SET @param = NULL

请注意,您经过的长度不会太大。这反映了SQL Server中定义的参数的最大长度,而不是所传递的数据的长度。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/398492.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号