- 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/
我了解堆栈和堆的基本概念,但如果有任何一个可以解决以下困惑,那就太好了: 是否为整个应用程序流程或项目中开始的每个线程都创建了一个新堆栈? 是否为整个应用程序进程或项目中开始的每个线程都创建了一个新堆
我已经阅读了无数关于 C# 4.0 新特性的博客、帖子和 StackOverflow 问题。甚至新的 WPF 4.0 功能也开始公开发布。我找不到并且想知道的: 从 C#/WPF 开发人员的角度来看,
最近,我的 asp.net 应用程序崩溃了。我在 Windows 上获得了事件日志,两种类型的异常消息: Application: w3wp.exe Framework Version: v4.0.3
我了解当前状态的 CLR 绑定(bind)到 Windows 操作系统,并通过在内部使用 Win32 API 提供各种服务。 由于 .NET Core 是独立于平台的,这基本上意味着相同的 IL 代码
AFAIK,try 和 finally block 用于执行一段可能会抛出一些异常的代码,我们还添加了 catch block ,如果我们准备处理某种类型的异常和/或将它们排除在外,比如 FileIO
问题: 线程中的未处理异常进入 CLR来自非托管代码不会触发“正常”未处理的异常 CLR 处理。 在下面的代码中,使用 C++ 调用 CSSimpleObject.GetstringLength()
JVM/CLR 如何执行 JIT 编译的原生代码?是通过一些代码注入(inject)还是通过将代码复制到可执行内存?允许动态代码执行的系统调用是什么? 最佳答案 我可以在 CACAO VM 中解释我们
我从事的项目需要 .Net 与非托管代码的互操作性。几周前我开始使用 .Net,虽然我在 C/C++ 方面有很多经验,但我很惊讶 CLR 如何处理 P/Invoke。这是详细信息。我的同事写了这个函数
在哪里可以找到 ODP 到 CLR 类型映射的列表?在 Oracle 数据库上,NUMBER(9,0) 类型在 .NET 应用程序中作为 MS Oracle 驱动程序的 System.Decimal
我有一个 Ubuntu 12.04。我尝试在我的 python 代码中导入 clr,但出现此错误。 我浏览了链接。但这一切都是徒劳的。有没有办法检查“clr”存在?如何查看模块是否存在? 最佳答案 您
我提到了 this somewhat similar question在问这个之前,但无法解决我的问题 我正在查看一个包含许多解决方案的旧应用程序。问题发生在其中一个解决方案中(比如 S)。这是情况:
假设我有一个旧的应用程序,它将尝试加载外部程序集。 旧应用程序编译为 CLR 2。 新程序集编译为 CLR 4。 我希望能够在 CLR 4 中运行那个旧应用程序。我记得有一些 xml manifest
我可以编写、编译并成功运行以下 IL 程序,并将 .maxstack 大小设置为 1,该值太低,因为该程序在某个时间点堆栈上有两个值(即 2+2==4) 。该程序不会在 CLR 中崩溃,并以“Hell
.Core CLR 与 Mono CLR 有什么区别?那么微软为什么要维护不同的运行时环境呢? 最佳答案 两者都是 .NET Standard 的实现,但它们具有不同的实现细节。 Mono从历史上看,
我正在尝试使用以下配置创建一个 Visual C++ Win32 控制台应用程序:操作系统:Windows 7 Visual Studio :VS 2012公共(public)语言运行时支持:公共(p
// This is the main DLL file. #include "stdafx.h" #include "Tga2DCLI.h" //#include #include Tga2DC
我有两个项目的解决方案。第一个是基本类库项目,其中包含在多个服务端点 (DataContract.dll) 之间共享的类的定义。第二个是将使用共享程序集中定义的类的 SQL CLR 项目。在我的本地机
我尝试创建一个使用 Windows 窗体的 .NET 控制台应用程序来创建和保存屏幕截图。在创建新的控制台应用程序项目时,我尝试使用 COM 引用通过依赖项导入 System.Windows.Form
DOS 变成 Windows 的方式是一样的吗? 我们似乎最终支持和开发了 Microsoft 的三个平台,我不确定边界应该在哪里。 为什么不能将 CLR 的好处(例如类型安全、内存保护等)内置到 W
在 VC++ .Net 中,Clr/Safe (/clr:safe) 和 Clr/Pure (/clr:pure) 是什么意思? 最佳答案 来自doc : /clr:pure Produces a M
我是一名优秀的程序员,十分优秀!