views:

34

answers:

2

I wrote an asp.net web app which uses SMO against SQL Server 2008 to be able to run some DB scripts. It references these assemblies (in the C:\Program Files\Microsoft SQL Server\100\SDK\Assemblies folder):

Microsoft.SqlServer.ConnectionInfo
Microsoft.SqlServer.Management.Sdk.Sfc
Microsoft.SqlServer.Smo

The microsoft.sqlserver.batchparser.dll is not in this folder. Locally (32 bits machine, IIS7) I have no issue.

When I publish the app to my hosting provider (discountasp.net, SQL Server 2008, IIS7, 32bits too), I get this error:

Could not load file or assembly 'Microsoft.SqlServer.BatchParser, Version=10.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91' or one of its dependencies. The system cannot find the file specified.

I searched my local machine and I can't find this assembly. However it works well on this machine.

The "Microsoft SQL Server 2008 Setup Discovery Report" tool reports I have v10.1.2531.0 installed locally.

Thanks

+1  A: 

To get this dll, you will need to install the Microsoft SQL Server 2008 Management Objects (available from here). That particular dll gets installed into the GAC, which is why you probably cannot find it using a search.

As you are using a hosting provider, it would appear that they do not have this installed. Your choices are to get it installed by them (which is probably unlikely), or deploy the dll manually (which may be on dodgy licencing ground).

adrianbanks
When I try to install SMO, the installer says I already have a higher version installed. Since I am able to reference Microsoft.SqlServer.Smo from my project, I guess this confirms it.
Nicolas Cadilhac
@Nicolas: yes, you will have this installed locally. It is not however installed on your hosting provider, hence the problem you are having.
adrianbanks
Calling gacutil /l shows me batchparser is in the GAC, however the references dialog box in VS2010 won't show it to me. Going manually into the GAC to extract the assembly and it is in the GAC_32 folder, not GAC_MSIL. Anyway, adding this to Reflector shows it has a reference to Microsoft.VisualC.... pretty odd.
Nicolas Cadilhac
@Nicolas: according to [this](http://blogs.msdn.com/b/mwories/archive/2005/05/02/smofaq.aspx) page, that particular dll is platform-specific (ie. there are both 32 and 64 bit versions).
adrianbanks
I have no idea how to deploy SMO on my hosting provider... See my other comment in the other answer (for the GAC). I can't install the latest "Microsoft SQL Server 2008 Feature Pack, April 2009" either (hoping to find redistributable package inside) because it always complain I have something newer already installed
Nicolas Cadilhac
@Nicolas: You could manually extract the dll from the msi (instructions [here](http://www.adrianbanks.co.uk/?p=64)) and deploy that, but I'm not sure what the licencing implications are.
adrianbanks
A: 

You need to have the SMO components installed on your hosting provider as well. You can download them here.

Joe Stefanelli
Well, obviously I can't install an msi on a shared host. Let me call them to know what they say about SMO.
Nicolas Cadilhac
discountasp won't install that, so does it mean I have to extract the dll + its dependency (Microsoft.VisualC) and put it in my bin folder?
Nicolas Cadilhac