Как создать DSN для SQL Server с использованием C#?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using Microsoft.SqlServer.Management.Common;
using Microsoft.SqlServer.Management.Smo;
using System.Data.SqlClient;
using Microsoft.Win32;
using System.Runtime.InteropServices;
[DllImport("ODBCCP32.dll")]
private static extern bool SQLConfigDataSource(IntPtr parent, int request, string driver, string attributes);
namespace CopyDatabase
{
public partial class Synchronize : Form
{
public Synchronize()
{
InitializeComponent();
}
private void Synchronize_Load(object sender, EventArgs e)
{
Server srv = new Server();
String[] s = { "master", "tempdb", "model", "msdb", "Resource", "distribution" };
foreach (Database database in srv.Databases)
{
int flag = 0;
for (int i = 0; i < s.Length; i++)
{
if (String.Compare(database.Name, s[i], true) == 0)
{
flag = 1;
break;
}
}
if (flag == 0)
{
cmbSource.Items.Add(database.Name);
cmbDest.Items.Add(database.Name);
}
}
}
private void button1_Click(object sender, EventArgs e)
{
string str = "SERVER=HOME\0DSN=MYDSN\0DESCRIPTION=MYDSNDESC\0DATABASE=DBServer\0TRUSTED_CONNECTION=YES";
SQLConfigDataSource((IntPtr)0, 4, "SQL Server",str);
}
}
}
Кто-нибудь может помочь мне удалить следующие ошибки?
Ошибка 1 Ожидаемый класс, делегат, перечисление, интерфейс или структура C:\Documents and Settings\Pavan\ Мои документы \Visual Studio 2008\Projects\CopyDatabase\CopyDatabase\Synchronize.cs 17 23 CopyDatabase
,
Ошибка 2 Имя 'SQLConfigDataSource' не существует в текущем контексте C:\Documents and Settings\Pavan\ Мои документы \Visual Studio 2008\Projects\CopyDatabase\CopyDatabase\Synchronize.cs 67 13 CopyDatabase
2 ответа
Решение
Без остальной части вашего кода для контекста моя WAG состоит в том, что вы не объявили класс вокруг extern и обработчика кликов.
Если вам нужно только динамически создать SQL Dsn, просто измените этот код на эту структуру:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using Microsoft.Win32;
using System.Runtime.InteropServices;
namespace CopyDatabase
{
public partial class Synchronize : Form
{
[DllImport("ODBCCP32.dll")]
private static extern bool SQLConfigDataSource(IntPtr parent, int request, string
driver, string attributes);
public Synchronize()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
string str = "SERVER=HOME\0DSN=MYDSN\0DESCRIPTION=MYDSNDESC\0DATABASE=DBServer\0TRUSTED_CONNECTION=YES";
SQLConfigDataSource((IntPtr)0, 4, "SQL Server",str);
}
}