SQL Server 接続 C#, VB.net

C#, VB.netでSQL Serverに接続する簡単な例。

C#

//SQL Serverへの接続
private int SQLExec()
{
  try
  {
    var res = 0;
    var connectionString = GetConnectionString();
    var queryString = “SELECT count(*) FROM ~”;

    using (SqlConnection cn = new SqlConnection(connectionString))
    using (SqlCommand cmd = new SqlCommand(queryString, cn))
    {
      cn.Open();
      cmd.CommandType = CommandType.Text;
      cmd.CommandTimeout = 120;
      res = (int)cmd.ExecuteScalar();
    }

    return res;
  }
  catch (Exception ex)
  {
    var ErrCaption = Application.ProductName + “(” + System.Reflection.MethodBase.GetCurrentMethod().Name + “)”;
    Debug.WriteLine(ErrCaption + ” ” + ex.Message);
    return -1;
  }
}

//接続文字列作成 Windows認証
private string GetConnectionString()
{
  var builder = new SqlConnectionStringBuilder()
  {
    IntegratedSecurity = true, // Windows認証
    InitialCatalog = “DB名”,
    DataSource = “(local)”
  };
  return builder.ToString();
}

//接続文字列作成 SQL Server認証
private string GetConnectionString2()
{
  var builder = new SqlConnectionStringBuilder()
  {
    IntegratedSecurity = false, // SQL Server認証
    InitialCatalog = “DB名”,
    DataSource = “(local)”,
    UserID = “ユーザー名”,
    Password = “パスワード”
  };
  return builder.ToString();
}


VB.net

‘SQL Serverへの接続
Private Function SQLExec() As Integer
  Try
    Dim Res As Integer = 0
    Dim connectionString As String = GetConnectionString()
    Dim queryString As String = “SELECT count(*) FROM ~”

    Using cn As New SqlConnection(connectionString)
      Using cmd As New SqlCommand(queryString, cn)
        cn.Open()
        cmd.CommandType = CommandType.Text
        cmd.CommandTimeout = 120
        Res = cmd.ExecuteScalar
      End Using
    End Using

    Return Res
  Catch ex As Exception
    Dim ErrCaption As String = My.Application.Info.ProductName & “(” & Reflection.MethodBase.GetCurrentMethod.Name & “)”
    Debug.WriteLine(ErrCaption + ” ” + ex.Message)
    Return -1
  End Try
End Function

‘接続文字列作成 Windows認証
Private Function GetConnectionString() As String
  Dim builder = New SqlConnectionStringBuilder With {
    .IntegratedSecurity = True, ‘Windows認証
    .InitialCatalog = “DB名”,
    .DataSource = “(local)”
  }
  Return builder.ToString
End Function

‘接続文字列作成 SQL Server認証
Private Function GetConnectionString2() As String
  Dim builder = New SqlConnectionStringBuilder With {
    .IntegratedSecurity = False, ‘SQL Server認証
    .InitialCatalog = “DB名”,
    .DataSource = “(local)”,
    .UserID = “ユーザー名”,
    .Password = “パスワード”
  }
  Return builder.ToString
End Function

SQL Server プログラムからストアドにデーターテーブルを渡す方法

VB.NETなどのプログラムからSQL Serverのストアドへテーブルデーターを渡すには、ユーザー定義テーブル型を利用する。
なお、ユーザー定義テーブル型はSQL Server2008以降で使用できる。

手順(1) ユーザー定義テーブル型の作成と権限設定

    CREATE TYPE [dbo].[UserTableTypeInt1] AS TABLE(
    [id] [int] NULL
    )

    ストアドで使うには作成したユーザー定義型に実行(EXECUTE)権限を設定する必要がある。
    GRANT EXECUTE ON TYPE::[dbo].[UserTableTypeInt1] TO ユーザー名;

    ManagementStudioから権限を設定する場合は、
    [プログラミング]-[種類]-[ユーザー定義テーブル型]で、作成したテーブル型を右クリックでプロパティーから権限を設定するが、なぜか実行権限は表示されないので制御(CONTROL)権限を設定する。
    制御権限を設定するとその他の全ての権限も暗黙的に設定される。

手順(2) ストアドの作成

    CREATE PROCEDURE stTest1
       @a1 UserTableTypeInt1 READONLY — ユーザー定義テーブル型
    AS
    BEGIN
        UPDATE Table1 SET c1 = 0 WHERE ID IN (SELECT id FROM @a1)
    END
    GO

手順(3) 呼び出し側プログラムの作成

    Dim cn As SqlClient.SqlConnection

    Private Sub Test()
        Dim cmd As New SqlClient.SqlCommand
        Try
           ‘ストアドに渡すDataTableの作成
            Dim dt1 As New DataTable
            dt1.Columns.Add(“ID”, GetType(Integer))
            dt1.Rows.Add(1)
            dt1.Rows.Add(2)
            dt1.Rows.Add(3)

            ‘ストアドの実行
            cmd.Connection = cn
            cmd.CommandText = “stTest1”
            cmd.CommandType = CommandType.StoredProcedure
            cmd.Parameters.Clear()
            cmd.Parameters.Add(“@a1”, SqlDbType.Structured)
            cmd.Parameters(“@a1”).TypeName = “UserTableTypeInt1”
            cmd.Parameters(“@a1”).Value = dt1 ‘DataTableをパラメーターとして渡す
            Dim res1 As Integer = cmd.ExecuteNonQuery()
        Finally
            cmd.Dispose()
        End Try
    End Sub


参考:
https://technet.microsoft.com/ja-jp/library/bb522526 (ユーザー定義テーブル型)

Windows8/8.1 + SQL Server での不具合(高速スタートアップ)

Windows8/8.1にインストールしたSQL Serverに接続すると、
データーにアクセスできずに、
ログを見ると次のようなエラーが発生している場合がある。

エラー: 823、重大度: 24、状態: 2。
エラー: 9001、重大度: 21、状態: 4。
Error: 17053, Severity: 16, State: 1.
The operating system returned error 21(デバイスの準備ができていません。)
オペレーティング システムにより、ファイル ‘***’ のオフセット 0x00000000f20000 で 読み取り 中の SQL Server にエラー 21(デバイスの準備ができていません。) が返されました。
Write error during log flush.
などのエラーがログに記録されている。

Windows8/8.1では高速スタートアップという機能が採用され、
シャットダウンが本当のシャットダウンではなく休止状態に近い状態であり、
これが悪さをしてSQL Serverが正常に立ち上がっていないと思われる。
高速スタートアップを無効にして立ち上げ直せばデーターにアクセスできるようになる。

Windows 8 / 8.1で高速スタートアップを無効にする方法
(NECサイト)

高速スタートアップは大して高速にならないし、
他にも不具合が起きやすいと思うので
SQL Serverを使わない場合でも無効にしておいたほうがいいだろう。