向 Sql Server 发送空参数

2024-01-30

我有一个SqlCommand我用来更新数据库表的对象,但它不能正确解释我的空值。

这是 SQL:

UPDATE dbo.tbl 
SET param1 = @param1, 
param2 = @param2,
param3 = @param3,
param4 = @param4, 
param5 = @param5, 
param6 = @param6, 
param7 = @param7, 
param8 = @param8, 
param9 = @param9, 
param10 = @param10 
WHERE param11 = @param11

我尝试过像这样可以为空的空合并参数,但没有取得任何成功。除非另有说明,所有参数都是字符串:

command.Parameters.AddWithValue("@param1", param1 ?? DBNull.Value);
command.Parameters.AddWithValue("@param2", param2 ?? DBNull.Value);
command.Parameters.AddWithValue("@param3", param3 ?? DBNull.Value);
command.Parameters.AddWithValue("@param4", param4 ?? DBNull.Value);
command.Parameters.AddWithValue("@param5", param5 ?? DBNull.Value);
// param6 is nullable type DateTime?
command.Parameters.AddWithValue("@param6", param6 ?? DBNull.Value); 
command.Parameters.AddWithValue("@param7", param7 ?? DBNull.Value);
// param8 is nullable type DateTime?
command.Parameters.AddWithValue("@param8", param8 ?? DBNull.Value); 
command.Parameters.AddWithValue("@param9", param9 ?? DBNull.Value);
// param10 nullable type float?
command.Parameters.AddWithValue("@param10", param10 ?? DBNull.Value); 
command.Parameters.AddWithValue("@param11", param11 ?? DBNull.Value);

我收到这样的异常:

The parameterized query '(@param1 nvarchar(4000),@param2 nvarchar(4000),@param3 nvarc' expects the parameter '@param4', which was not supplied.

我还尝试在将每个参数添加到 SqlCommand 对象后循环遍历每个参数,以设置 DbNull.Value 如果参数值为 null,如下所示:

foreach (SqlParameter parameter in command.Parameters)
{
    if (parameter.Value == null)
    {
        parameter.Value = DBNull.Value;
    }
}

但是,这种方法会导致异常:

String or binary data would be truncated.
The statement has been terminated.

将 null 参数传递给 a 的最佳实践是什么SqlCommand?我不想简单地传递默认值(如果它们为空),因为数据库架构允许空值。


尝试这个 :

command.Parameters.AddWithValue("@param1", param1 ?? Convert.DBNull);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

向 Sql Server 发送空参数 的相关文章

随机推荐

  • 按下按钮时如何隐藏/显示元素?

    我正在尝试学习如何使用 Eclipse IDE 开发 Android 我现在想做的是在按下按钮时使隐藏的 TableLayout 可见 但是 我不知道需要在按钮的 OnClick 属性中放入什么内容 另外 是否有任何在线教程可以帮助我学习如
  • 重新绘制自定义标签

    React Recharts 的自定义标签不适用于条形图 http jsfiddle net xpko4e7e http jsfiddle net xpko4e7e
  • 按键合并地图

    假设我有两张地图 val a Map 1 gt one 2 gt two 3 gt three val b Map 1 gt un 2 gt deux 3 gt trois 我想按键合并这些映射 应用一些函数来收集值 在这种特殊情况下 我想
  • 在休眠中加载百万行

    如果我想在休眠中获取百万行 它会如何工作 休眠会崩溃吗 我该如何优化它 通常您不会为此使用 hibernate 如果需要执行批量操作 请使用 sql 或 hibernate 包装器进行批量操作 加载数百万条记录不可能为您的应用程序带来良好的
  • __len__ 无法返回大数字

    下面的代码 class Container def len self return 10 100 c Container print len c returns OverflowError 无法将 int 放入索引大小的整数中 我读过这个问
  • DynamoDB 在本地计算机中创建表

    我已将 DynamoDB jar 下载到本地 Windows 计算机 并能够使用下面的命令启动服务 java jar DynamoDBLocal jar dbPath 我可以使用 localhost 8000 shell 访问 Web 控制
  • 如何以矢量化方式查找特定轴上二维数组的唯一向量?

    我有一个形状数组 n t 我想将其视为一个时间序列n vectors 我想知道独特的n vector沿线存在的价值观t dimension以及相关的t indices对于每个独特的向量 我很乐意使用任何合理的平等定义 例如numpy uni
  • 如何获取单独数据集中 cte 的行计数?

    我已经找到了一种使用 CTE 和 Row Number 函数从数据库获取快速分页结果的方法 如下所示 DECLARE PageSize INT 1 DECLARE PageNumber INT 2 DECLARE Customer TABL
  • 压缩和utf8编码

    有人可以告诉我为什么我在此过程中丢失信息吗 一些 utf 8 字符似乎未解码 Biography u003clink type or Steve Blunt u0026 Marty Kelley但其他人却这样做 Name 朱敬 Creati
  • 是否可以从管道中的 sh DSL 命令捕获标准输出

    例如 var output sh echo foo echo output output 我会得到 output 0 所以 显然我得到的是退出代码而不是标准输出 是否可以将标准输出捕获到管道变量中 以便我可以获得 output foo作为我
  • 处理多个项目时.NET Core 2.0 appsettings.json 文件位置

    我正在开发一个由多个项目组成的 NET Core 2 1 103 WebAPI 应用程序 每个项目都需要有自己的 appsettings json 文件 每个项目都位于主 解决方案 文件夹内自己的子目录中 这是目录结构的简化版本 其中包含我
  • 致命错误:在 AppKernel.php 中找不到类

    我已经按照 Symfony 文档生成了一个新的 Bundle ImgBundle 但是当在浏览器中重新加载应用程序时 它无法识别该包的主类 这是我的 ImgBundle php
  • ReSharper Unit Test Runner 忽略部署项配置

    我正在使用 Resharper 6 1 对新项目进行单元测试 它似乎忽略了 local testsettings 文件的 Deployment 部分 我尝试在 ReSharper gt 选项 gt 单元测试 gt MSTest gt 使用此
  • Java泛型和枚举,模板参数丢失

    我有一个相当复杂的结构 但它没有按预期工作 这就是我所做的 public interface ResultServiceHolder
  • 使用 Jackson 解析 Json 文件

    TestSuite TestSuiteInfo description parse TestCase TestCaseData sequence sequential testNumber 2 testCaseFile testcase W
  • 如何在android中快速上传大视频文件到服务器

    您好 我正在使用 Volley Multi part Api 将大型视频文件上传到服务器 但上传到服务器需要很长时间 分割我的视频文件并发送到服务器是否更好 如果更好 请向我提供代码 我该怎么做 如果不是 将大视频文件快速上传到服务器的最佳
  • 在 C# 中比较两个列表中的重复项

    我有两个这样的列表 List
  • 将 ASP.NET updatepanel 与 jQuery UI DatePicker 组合时出现奇怪的错误

    我创建了一个结合了内联的页面jQuery UI 日期选择器 http docs jquery com UI Datepicker 当用户单击新日期来更新某些数据时 我不想启动对更新面板的回调 现在 此页面有多个更新面板 不要问 因此我需要检
  • 如何使用 asp.net MVC razor 将两个模型组合成一个模型并将其传递给视图

    我试图将两个模型 tblCategories 和 tblProducts 组合成一个模型并将其传递给视图 但没能做到 tblCategory cs主模型有以下数据 namespace ScaffoldCreate Models using
  • 向 Sql Server 发送空参数

    我有一个SqlCommand我用来更新数据库表的对象 但它不能正确解释我的空值 这是 SQL UPDATE dbo tbl SET param1 param1 param2 param2 param3 param3 param4 param