FileLoadException / Msg 10314 Error Running CLR St

2019-01-17 03:10发布

Receiving the following error when attempting to run a CLR stored proc. Any help is much appreciated.

Msg 10314, Level 16, State 11, Line 1
An error occurred in the Microsoft .NET Framework while trying to load assembly id 65752. The server may be running out of resources, or the assembly may not be trusted with PERMISSION_SET = EXTERNAL_ACCESS or UNSAFE. Run the query again, or check documentation to see how to solve the assembly trust issues. For more information about this error: 
System.IO.FileLoadException: Could not load file or assembly 'orders, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. An error relating to security occurred. (Exception from HRESULT: 0x8013150A)
System.IO.FileLoadException: 
   at System.Reflection.Assembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, Assembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
   at System.Reflection.Assembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, Assembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
   at System.Reflection.Assembly.InternalLoad(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
   at System.Reflection.Assembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
   at System.Reflection.Assembly.Load(String assemblyString)

5条回答
做个烂人
2楼-- · 2019-01-17 03:36
ALTER AUTHORIZATION ON DATABASE::mydb TO sa;
ALTER DATABASE [myDB] SET TRUSTWORTHY ON
GO
查看更多
Explosion°爆炸
3楼-- · 2019-01-17 03:39

Does your assembly do file I/O? If so, you must grant the assembly permission to do this. In SSMS:

  1. Expand "Databases"
  2. Expand the node for your database
  3. Expand "Programmability"
  4. Expand "Assemblies"
  5. Right-click your assembly, choose Properties
  6. On the "General" page, change "Permission set" to "External access"
查看更多
贼婆χ
4楼-- · 2019-01-17 03:42

Applied all of the above suggestion and it failed. Then I recompiled my source code with "Any CPU" option, and it worked!

This link helped: SQL Server failed to load assembly with PERMISSION

查看更多
Fickle 薄情
5楼-- · 2019-01-17 03:47

Build your project with ANY CPU configuration. I had this problem when compiled my own project with x86 configuration and tried to run it on x64 SQL server.

查看更多
唯我独甜
6楼-- · 2019-01-17 03:50

Ran the SQL commands below and the issue appears to be resolved.

USE database_name
GO

EXEC sp_changedbowner 'sa'
ALTER DATABASE database_name SET TRUSTWORTHY ON 
查看更多
登录 后发表回答