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

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

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

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

1回答

1206閲覧

WPF C# DatePickerについて 初心者

退会済みユーザー

退会済みユーザー

総合スコア0

C#

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

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

0グッド

0クリップ

投稿2018/07/26 02:27

編集2018/07/26 02:29

DataGridについて。

private void Button_Register(object sender, RoutedEventArgs e) { var connecitonStiring = ConfigurationManager.ConnectionStrings["conndata"].ConnectionString; using (var con = new SqlConnection(connecitonStiring)) using (var cmd = con.CreateCommand()) { try { con.Open(); cmd.CommandText = @"INSERT INTO DataTbl (DATA) VALUES (@DATA)"; cmd.Connection = con; cmd.Parameters.AddWithValue("@DATA", dataPicker.Text); cmd.ExecuteNonQuery(); SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable dt = new DataTable("DATA"); da.Fill(dt); g1.ItemsSource = dt.DefaultView; } catch (Exception exception) { Console.WriteLine(exception.Message); throw; } finally { con.Close(); } dataGrid.Items.Refresh(); } }

DataPickerで日付を選択し、上記のボタンを押すとデータベースに登録されるようになったのですが、
選択した日付が、2回データベースに登録されてしまいます。

2回登録されてしまう原因と、お手数ですが不必要な構文がございましたら、
ご指摘の程、宜しくお願いします。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

C#

1cmd.ExecuteNonQuery();

ここで一回実行されます。次に

C#

1SqlDataAdapter da = new SqlDataAdapter(cmd); 2DataTable dt = new DataTable("DATA"); 3da.Fill(dt);

ここで一回実行されます。
insert はこの二回実行されています。

また da にはまともなデータが入っていないと思います。
Fill するにはコマンドとして insert でなく select を使ってください。

投稿2018/07/26 02:42

Zuishin

総合スコア28660

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/07/26 04:55

ExecuteNonQueryで登録を1回に直すことができました! 素早いご対応、ありがとうございます。 この度は、私の質問に3回も御回答していただき大変助かりました。 勝手ながらフォローさせていただきました。 また機会がありましたら宜しくお願いいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問