首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ExecuteScalar返回空值

ExecuteScalar返回空值
EN

Stack Overflow用户
提问于 2015-06-11 02:26:25
回答 1查看 204关注 0票数 0

存储过程:

代码语言:javascript
复制
dbo.GetLDate
select DateEntered from Table1 where Id = 4, Gid=5

结果:

代码语言:javascript
复制
Executed Successfully

要验证的新查询:

代码语言:javascript
复制
DECLARE @LDate datetime
EXEC @LDate =  GetLDate 4,5

结果:

代码语言:javascript
复制
DateEntered
2014-02-13 06:21:43.600

因此,工作得很好

创建的最终存储过程:

代码语言:javascript
复制
EXEC @LDate =  GetLDate 4,5
Select 1

在C#中

代码语言:javascript
复制
int? id = _database.ExecuteScalar() as int?;

在这里,每次我只得到空值。但是我选择了1,我仍然得到空值。这可能是什么原因呢?

EN

回答 1

Stack Overflow用户

发布于 2015-06-11 02:29:49

您正在选择字符串'1',但无法使用cast将其转换为int?。因此,您将得到null。

使用:

代码语言:javascript
复制
SELECT 1 --without single quotes

或者,您可以像这样使用Convert.ToInt32

代码语言:javascript
复制
int? id = Convert.ToInt32(_database.ExecuteScalar());

考虑以下示例:

代码语言:javascript
复制
object obj = "1";
int? id = obj as int?;

当从"1" (string)转换到int/int?将失败时,您将得到null

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30764427

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档