- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试向数据库执行插入命令,其中一列的类型为 nvarchar(MAX)。插入命令是使用.NET SqlCommand 类创建的,每个参数由一个SqlParameter 对象表示。
我的命令总是被执行,但是当我传递长度很大(10000+个字符)的字符串并且该字符串用作插入后映射到 nvarchar(MAX) 类型列的 SqlParameter 的值时,该特定列留空。我再说一遍,没有抛出异常,执行了 INSERT 命令,但列为空。
以下示例是我尝试创建参数的方式:
// message is the large string variable
// first solution
insertCommand.Parameters.Add("@message", SqlDbType.NVarChar, -1);
// second solution
insertCommand.Parameters.Add("@message", SqlDbType.NVarChar, message.Length);
// third solution
insertCommand.Parameters.Add("@message", SqlDbType.NVarChar, message.Length * 2);
这些解决方案都没有给出结果。如果有人知道问题是什么,请告诉我。
我使用的是 MS SQL Server 2008。
提前致谢。
最佳答案
根据MSDN
NVarChar:
String. A variable-length stream of Unicode characters ranging between 1and 4,000 characters. Implicit conversion fails if the string is greater than 4,000 characters.Explicitly set the object when working with strings longer than 4,000 characters.
这里是ntext:
String. A variable-length stream ofUnicode data with a maximum length of2 30 - 1 (or 1,073,741,823)characters.
另请查看this
关于.net - 使用非常长(10000+ 个字符)的字符串作为 SqlParameter 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3718663/
我正在尝试使用这些命名空间之一 //using Microsoft.Data.SqlClient; using System.Data.SqlClient; 我的模型 public class Get
我将我的项目从 ASP.NET Core 2.2 迁移到 ASP.NET Core 3.0。现在我得到了这个异常(exception)。在 ASP.NET Core 2.2 中,它使用 FromSql
我想知道如何SqlParameter知道没有指定的类型吗? 例如,在实例化参数对象时,您不需要指定 DB 类型。以某种方式执行命令时,.net 会为您处理此问题。在幕后是否有某种转换正在发生?当你做/
我们有一个代码块,它创建一个 sqlParameters 列表,然后将它们传递给存储过程。要求根据输入文本框是否为空有条件地使一些值无效。 基本代码: var SqlParams = new List
如何设置SqlParameter的值相当于 SQL INSERT 语句的 DEFAULT 关键字? MSDN documentation表示“使用 null 或不设置 Value 以使用参数的默认值。
如何设置SqlParameter的值相当于 SQL INSERT 语句的 DEFAULT 关键字? MSDN documentation表示“使用 null 或不设置 Value 以使用参数的默认值。
我想从我的代码中删除手动转义。而不是这个,我想使用 SqlParameter 对象。 foreach (ThreadPost post in ThreadPosts) { string ne
Sql命令构建 我已经构建了如下的 Sql 命令: string _InsertVehicleQuery = "INSERT INTO VSI_VehicleRecords(StockNumb
SqlParameter[] _parameters = { new SqlParameter( "@IDNumber", Person.IDNumber ),
给定以下代码行: cmd.Parameters.Add(new SqlParameter("@displayId", SqlDbType.NVarChar).Value = customer.Disp
我正在尝试访问一个存储过程,但我收到一条错误消息: Procedure or function 'getbug' expects parameter '@bugID', which was not s
我需要检查 SqlParameter 对象的值并根据特殊标签更改它。即:[BB] ==> 棒球,[FP] ==> 快投。 我可以用这样的附加函数来做到这一点: _params.Add(new SqlP
我正在尝试转换: command.Parameters.Add (new SqliteParameter (DbType.Int32) { Value = id }); 到一个普通的 SqlParam
我有一个网络服务,所以处理程序一直被同时调用多次。 我在里面创建了 SqlConnection 和 SqlCommand。我必须执行大约 7 个不同的命令。不同的命令需要不同的参数,所以我只添加一次:
我收到这个错误: System.Data.SqlClient.SqlException: 'The parameterized query '(@inputKarakterSoort varchar(
我有一个 SqlCommand我想打电话Prepare()在谁的CommandType = Text (它 不能 是一个存储过程)。 为了做到这一点,我需要设置 Size参数上的属性非零,否则抛出异常
这个问题已经有答案了: SQL Server error "Procedure expects parameter" (1 个回答) 已关闭 8 年前。 我正在尝试从 C# 程序访问存储过程,令人难以
我正在使用最新版本的 MiniProfiler,一切都已按我的预期设置和工作。我唯一的问题是 SqlParameters 没有显示。 例如,我正在运行一个存储过程:- var cmd = dbcon.
我有一个 SqlCommand,它运行一个包含两个整数输出参数的存储过程。就在 SqlCommand 运行之前,我可以看到输出参数设置为正确的值,但是当命令实际执行时,它对参数 1 使用 NULL,对
我正在开发一个必须支持多种语言的应用程序。为了解决特殊字符问题,我在文本字段中使用了 NVarhcar。所以我对文本字段的 SQL 查询是 insert into tbl_text(text)valu
我是一名优秀的程序员,十分优秀!