FileLoadException / Msg 10314 Error Running CLR Stored Procedure

35

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)
sql-server
sqlclr
asked on Stack Overflow Sep 16, 2008 by homeskillet • edited Aug 23, 2015 by Solomon Rutzky

5 Answers

70

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 
answered on Stack Overflow Sep 16, 2008 by homeskillet • edited Aug 31, 2012 by Justin Dearing
8

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.

answered on Stack Overflow Aug 31, 2011 by nuwanda
2

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

answered on Stack Overflow May 1, 2012 by 101V • edited May 1, 2012 by Josh Darnell
0

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"
answered on Stack Overflow Sep 16, 2008 by Craig Stuntz
0
ALTER AUTHORIZATION ON DATABASE::mydb TO sa;
ALTER DATABASE [myDB] SET TRUSTWORTHY ON
GO
answered on Stack Overflow Sep 15, 2014 by Musakkhir Sayyed

User contributions licensed under CC BY-SA 3.0