- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
下面这两种方法类似,只是一种方法处理空值,另一种则不处理。为了处理空值,它使用 SqlString 类型并检查“get_IsNull”属性。
为什么第一个可能会在 SQL CLR 内运行时导致错误“执行用户定义例程或聚合“CheckMailingAddress”时发生 .NET Framework 错误:.”
,而第二个可能会导致错误有一个没有吗?
特别是,TSQL 错误是“消息 10329,级别 16,状态 49,第 1 行 .Net Framework 执行已中止。”
.method public hidebysig static bool CheckMailingAddress(valuetype [System.Data]System.Data.SqlTypes.SqlString param0) cil managed
{
.maxstack 8
L_0000: ldarga.s param0
L_0002: nop
L_0003: nop
L_0004: call instance bool [System.Data]System.Data.SqlTypes.SqlString::get_IsNull()
L_0009: brfalse L_0010
L_000e: ldc.i4.1
L_000f: ret
L_0010: ldarga.s param0
L_0012: nop
L_0013: nop
L_0014: call instance string [System.Data]System.Data.SqlTypes.SqlString::get_Value()
L_0019: call class DatabaseValues.MailingAddress DatabaseValues.MailingAddress::op_Explicit(string)
L_001e: pop
L_001f: ldc.i4.1
L_0020: ret
}
.method public hidebysig static bool CheckMailingAddress(string param0) cil managed
{
.maxstack 8
L_0000: ldarg.0
L_0001: call class DatabaseValues.CheckMailingAddress DatabaseValues.CheckMailingAddress::op_Explicit(string)
L_0006: pop
L_0007: ldc.i4.1
L_0008: ret
}
请记住,据我所知,MSIL 是正确的,因为这两种方法在独立应用程序中调用时都可以工作。仅当在 SQL CLR 内部调用时,两者中的第一个才会崩溃。在 SQL CLR 中,该函数是使用“nvarchar(4000)”类型定义的,据我所知,该类型应该与 SqlString 配合良好。
我可能也可以使用“string”实现第一个方法,并且仍然执行 null 检查,但它使用 SqlString 来利用 INullable 接口(interface)属性“IsNull”和“Value”,因为它是通用代码的一部分可以使用其他 Sql* 类型的生成器。
对于那些被方法体中的 MSIL 分散注意力的人;忽略它。我重新编译了这些函数,什么也不做,我的观点是,当输入类型是“SqlString”而不是“string”时,CLR 会崩溃并终止,没有错误消息,并且返回值是 NULL 而不是正确。
//Crashes when input parameter is "SqlString"
.method public hidebysig static bool CheckMailingAddress(valuetype [System.Data]System.Data.SqlTypes.SqlString param0) cil managed
{
.maxstack 8
L_001f: ldc.i4.1
L_0020: ret
}
//Doesn't Crash when input parameter is "string"
.method public hidebysig static bool CheckMailingAddress(string param0) cil managed
{
.maxstack 8
L_0007: ldc.i4.1
L_0008: ret
}
最佳答案
我找到了问题的根源,并能够解决它,但我不确定详细信息。
在某个时候,我将 DeployDatabaseAssembly 项目切换为面向 .NET 4.0,并且 AssemblyBuilder 也必须生成面向 .NET 4.0 的程序集。将项目切换到目标 .NET 3.5 解决了该问题。
有趣的是,包含我所有数据类型的源 DLL (database.dll) 仍然以 .NET 3.5 为目标,并且是故意保留的,因为我知道 SQL Server 目前仅支持 CLR 2.0,这实际上使其与.NET 4.0,因为.NET 4.0 似乎需要 CLR 4.0。使用 ILMerge,我将包含生成函数的动态程序集与现有的 (.NET 3.5) database.dll 相结合。这最终导致了混合程序集 .NET 4.0 程序集,主要基于 .NET 3.5 功能和类。奇怪的是,我能够让使用基本“String”和“int”类型参数的函数正常工作,但 SqlString 类型导致崩溃......显然是因为它是从 .NET 4.0 System.Data.dll 中提取的,因为它在我的 DeployDatabaseAssembly 中被引用为“typeof(SqlString)”,它的目标是 .NET 4.0。奇怪的是,它崩溃了,没有任何类型的错误消息,也没有任何关于它与加载的 SQL CLR 模块不兼容的警告。
我希望我知道一种方法来强制在 .NET 4.0 应用程序中运行的 AssemblyBuilder 生成针对 .NET 3.5 的程序集...
我专注于 ILMerge 的输出,然后将 DeployDatabaseAssembly 切换回 .NET 4.0。顺便说一句,我在我的项目中使用 ILMerge 作为引用,因为它是一个 .NET 程序集。
通过像这样设置 ILMerge 选项:
ILMerge merger = new ILMerge();
merger.SetTargetPlatform( "v2", @"C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v3.5\Profile\Client");
生成的 DLL 部署到 SQL Server(与之前一样),但这次实际上运行没有错误。
有趣的是,如果我仅将目标平台路径中的“v3.5”替换为“v4.0”并尝试将程序集部署到 SQL Server,那么我会在部署期间立即收到一条有用的错误消息“为程序集“我的程序集名称”创建程序集失败,因为该程序集是为不受支持的 CLR 运行时版本构建的。”。奇怪的是,当我根本没有设置任何目标平台时,它会部署得很好,但在没有任何错误消息的情况下崩溃了。
关于sql-server - 为什么在 SQL Server CLR 中运行的一个函数可能会导致崩溃,而在独立应用程序中运行正常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5874719/
我如何使用 CQLINQ 获取当前方法的输入参数集合?有像“参数”或“参数”这样的集合,只有“NbParamenter”不适合我的目的。 最佳答案 事实上,CQLinq 还没有这个功能。但是,在许多情
我想知道是否有人知道我的 makefile 中独立的 @ 符号和“dir”命令在这里(第二行和第三行)的作用: $(BUILD)/%.o: %.cpp @mkdir -p $(dir $@)
我想知道是否有人知道我的 makefile 中独立的 @ 符号和“dir”命令在这里(第二行和第三行)的作用: $(BUILD)/%.o: %.cpp @mkdir -p $(dir $@)
我的机器上有带有 4 个 cpu 的 Ubuntu 14.04(nproc 恢复了 4 个)。我安装并执行 Spark Standalone 后(本地),我可以自己定义不同数量的奴隶。例如我想要有4个
我看到所有这些 iPhone 应用程序都带有内置的独立 webDav 服务器。是否有可以集成到现有应用程序中的独立(如在其自己的 IIS 中)C# webDAV 项目。 最佳答案 至少有两个用于 .N
我如何在独立的 Django 应用程序上进行迁移(即不属于任何项目的应用程序)。 例如在以下之后:https://docs.djangoproject.com/en/1.8/intro/reusabl
我目前正在使用 tortoiseSVN 对本地编程文件进行版本控制。我不运行 SVN 服务器,因为可以直接使用 tortoiseSVN(例如 http://invalidlogic.com/2006/
我有一些 Bootstrap 代码,当用户查看它时,它可以很好地为进度条部分设置动画。 然而它动画 全部 页面中的进度条而不是动画仅限 该查看部分中的进度条。结果,当用户转到进度条的另一部分时,这些已
我认为我们在 iOS 13.2/13.3 中发现了关于在独立模式下运行的 PWA 的回归。 由于在 iOS PWA 上无法访问 getUserMedia() 我们依赖 capture HTML5 输入
我有一个每周从系统运行一次的报告,并将数据导出到 Excel 文档中。我已经设置了将数据导出到 Excel 的工具,以便在格式化方面做得很好,但是一旦数据进入 Excel,我还需要做更多的事情。 是否
//值数组的格式为 { "var1", "val1", "var2", "val2",.. } public static String replaceMethod(String template,
当我在 eclipse 中运行我的项目时,它工作正常,当我将它导出为独立 jar 时,它会滞后。我使用相同的 vmargs,在 Eclipse 中尝试了 3 种不同的导出设置,似乎没有任何帮助 最佳答
我了解到 Java EE 中我非常喜欢的注释基础配置(@Resource)功能。然后我注意到注释实际上是 Java SE 的一部分。 所以我想知道是否可以将它与 Java SE 一起使用。我当然可以在
我无法理解为什么这种关系没有被持久化,并且程序不会正常退出,但在 Eclipse 中继续运行。 下面是我的代码,排除了包名: 主要: import java.io.BufferedInputStrea
我有一个在 Linux + Java 6 上运行的独立 Java 应用程序,它似乎被卡住了(没有生成日志)我如何在不使用任何其他工具(例如 jstack)的情况下获取此线程转储 尝试了以下命令,但它们
我正在非节点环境中构建应用程序,但我想利用 Babel 的 ES6 转译,以便我可以编写更好的代码并且仍然支持 IE11。 所以我继续包含在这里找到的独立文件: https://github.com/
扩展我对 MySQL 的理解。 1) 是否需要 64 位帮助?我是安装还是单独使用? 2) 如果我打算在 MySQL Community Service 中使用 64 位,它会影响仅提供 32 位的
我有一个独立的 Java 应用程序,我必须为其集成一个规则引擎。我应该使用属性文件或 XML 文件定义规则。我需要规则引擎来读取属性或 XML 文件中定义的这些规则,并相应地在应用程序中实现代码。 任
我是wiremock新手,我正在尝试使用它来记录我负责集成测试的java应用程序的请求和响应。 我知道我的命令将类似于: java -jar wiremock-1.57-standalone.jar
我到处寻找我的问题的解决方案,但我的问题有点具体...我需要有关如何创建独立 radioGroup 列表的建议,例如图示: o item1 • item1' • item2 或 item2' o it
我是一名优秀的程序员,十分优秀!