質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.54%

  • C#

    8811questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • SQL Server

    703questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

C#とデータベース SQL serverで接続の仕方が分かりません。

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 8,063

tomotomtony

score 5

C#でデータベースを操作したいと考えています。

目標

とりあえず、テーブルから何らかのデータを取り出して出力したいです。ちなみに今までデータベースを扱ったことはありません。

以下のような操作をしました。

  1. SQL server 2014をインストール
  2. ローカルにインスタンス(MSSQLLocalDB)が自動的に生成
  3. MSSQLLocalDBにTestDatabaseを作成
  4. C#プログラムを作成
  5. app.configを編集
  6. csファイルを変数
  7. 実行した結果エラー発生

参考URL
https://garafu.blogspot.jp/2016/05/how-to-connect-sqlserver-wcs.html

// 接続文字列の取得
    var connectionString = ConfigurationManager.ConnectionStrings["sqlsvr"].ConnectionString;←ここでエラー

    // データベース接続の準備
    var connection = new SqlConnection(connectionString);

    // データベースの接続開始
    connection.Open();

    // 実行するSQLの準備
    var command = new SqlCommand();
    command.Connection = connection;
    command.CommandText = @"SELECT count(*) FROM T_USER";

    // SQLの実行
    command.ExecuteNonQuery();

    // データベースの接続終了
    connection.Close();

↑をmain()の中で実行しました。

<connectionString>
     <add name="sqlsvr"
   connectionString="DataSource=TomohiroPC\SQLEXPRESS;Persist Security Info=True;Initial Catalog=TestDatabase;User ID=sa;Password=****"
   providerName="System.Data.SqlClient"/>
</connectionString>


↑App.configの一部

エラー内容

型 'System.Configuration.ConfigurationErrorsException' のハンドルされていない例外が System.Configuration.dll で発生しました

求める回答

  • エラーの原因
  • 解決方法
    *もっと簡単にデータベースを扱える方法があればぜひ教えてください。

今回はじめてデータベースに挑戦してみて、予想以上に苦戦しています 涙
回答よろしくお願いします!!

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • katsuya141

    2017/01/20 10:07

    app.configのconnectionStringはどうなっていますか?

    キャンセル

  • tomotomtony

    2017/01/20 22:02

    追加しました。

    キャンセル

回答 2

+2

App.Config(もしくはWeb.config)にちゃんとデータベース接続(<configuration>の<connectionStrings>のセクションに)の設定(例示のコードだと <add name="sqlsvr" から始まるセクションで)を正しく書いていますか?

そもそもConfigurationManager.ConnectionStringsは「既定構成の ConnectionStringsSection データを取得」だけの機能しかなく、都合よく接続文字列を生成してくれるものではありませんよ

ConfigurationManager.ConnectionStrings プロパティ

もっと簡単にデータベースを扱える方法があればぜひ教えてください

接続文字列を直書きするのが一番簡単かもです
SQLServerの統合認証を使っていれば

public string GetSQLServerConnectionString()
{
    return @"Data Source=[ここにSQLServerのコンピュータ名かIPアドレスを直書き];"
            + @"Initial Catalog=[データベース名を直書き];"
            + @"Integrated Security=True;";
}


が一番簡単ですかね

これで慣れたら、可変の部分を切り出したり、構成ファイルに接続文字列ごと外出ししたりされると、別のSQLServerにも繋げられたり、ビルドし直さなくてもよくなります

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

・エラーの原因

設定ファイルが正しく設定出来ているか確認を実施して下さい。
App.Configの内容が不正な可能性があります。
Xmlの設定におかしな部分はないでしょうか。

Visual Studio を利用されているのであれば、
ファイルを開いた状態で、[ツールバー]→[表示]→[エラー一覧]で
事前に確認出来ます。

・解決方法 

提供されているライブラリを利用する等、簡単な方法はありますが、
基礎ですのでしっかりと理解される事を推奨致します。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • C#

    8811questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • SQL Server

    703questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。