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

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

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

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

解決済

dataGridViewにチェックボックスをつけ削除(選択した情報を取得し削除)

yamaguti
yamaguti

総合スコア0

C#

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

2回答

0評価

0クリップ

6704閲覧

投稿2017/02/14 10:55

お世話になります。

パスワードを管理する、プログラム実装しているのですが、
現在照会画面を作り込んでおり、DBに登録されている内容をSELECTする部分まで完成しました。

次は削除したい情報にチェックボックスでチェックをつける。
チェックボックスをつけるところまでは、完了しました。

次は、このチェックした情報を取得しカラムを削除したいのですが、
どのように情報を取得すればいいのでしょうか?
よろしくお願いします。

C#

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using System.Data.SQLite; namespace WindowsFormsApplication4 { public partial class Itiran : Form { public Itiran() { InitializeComponent(); DataGridViewCheckBoxColumn column = new DataGridViewCheckBoxColumn(); dataGridView1.Columns.Add(column); } private void btnsintou_Enter(object sender, EventArgs e) { //新規登録ボタンを押下すると登録画面に遷移 Touroku Touroku = new Touroku(); Touroku.Show(); this.Visible = false; } private DataTable datatable = new DataTable(); protected override void OnLoad(EventArgs e) { dataGridView1.DataSource = datatable; base.OnLoad(e); } //テーブルの内容を表示 private void buttonkensaku_Click(object sender, EventArgs e) { //検索条件がない場合 if (txtSiteNm.Text == "") { //using (SQLiteConnection con = new SQLiteConnection("Data Source = C:\\Users/Desktop/WindowsFormsApplication4/myfriend.sqlite3")) using (SQLiteConnection con = new SQLiteConnection("Data Source = C:\\Users/Desktop/WindowsFormsApplication4 /myfriend.sqlite3")) using (SQLiteDataAdapter adapter = new SQLiteDataAdapter("select * from PASS_KANRI", con)) { //データグリッドビューのクリア datatable.Clear(); dataGridView1.DataSource = datatable; adapter.Fill(datatable); //No,SiteNm,LoginId,Password,BIKO カラム順 //テーブルの内容表示 //dataGridView1.Columns[0].HeaderText = ""; //dataGridView1.Columns[1].HeaderText = "No"; //dataGridView1.Columns[2].HeaderText = "サイト名"; //dataGridView1.Columns[3].HeaderText = "ログインIDまたはEmail等"; //dataGridView1.Columns[4].HeaderText = "パスワード"; //dataGridView1.Columns[5].HeaderText = "登録日"; //dataGridView1.Columns[6].HeaderText = "備考"; dataGridView1.Columns[0].HeaderText = "No"; dataGridView1.Columns[1].HeaderText = "サイト名"; dataGridView1.Columns[2].HeaderText = "ログインIDまたはEmail等"; dataGridView1.Columns[3].HeaderText = "パスワード"; dataGridView1.Columns[4].HeaderText = "登録日"; dataGridView1.Columns[5].HeaderText = "備考"; //行の幅を自動で調整する dataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells; } } else { string dbConnectionString = "Data Source = C:\\Users/Desktop/WindowsFormsApplication4 /myfriend.sqlite3"; using (SQLiteConnection cn = new SQLiteConnection(dbConnectionString)) { cn.Open(); using (SQLiteTransaction trans = cn.BeginTransaction()) { SQLiteCommand cmd = cn.CreateCommand(); //SELECT文 cmd.CommandText = "SELECT * from PASS_KANRI where SiteNm = @SiteNm"; //パラメータセット cmd.Parameters.Add("SiteNm", System.Data.DbType.String); cmd.Parameters["SiteNm"].Value = txtSiteNm.Text; //datatableのクリア datatable.Clear(); //datatableに検索結果をセット datatable.Load(cmd.ExecuteReader()); dataGridView1.DataSource = datatable; //dataGridView1.Columns[0].HeaderText = "ID"; //No,SiteNm,LoginId,Password,BIKO カラム順 ////テーブルの内容表示 //dataGridView1.Columns[0].HeaderText = ""; //dataGridView1.Columns[1].HeaderText = "No"; //dataGridView1.Columns[2].HeaderText = "サイト名"; //dataGridView1.Columns[3].HeaderText = "ログインID"; //dataGridView1.Columns[4].HeaderText = "パスワード"; //dataGridView1.Columns[5].HeaderText = "登録日"; //dataGridView1.Columns[6].HeaderText = "備考"; dataGridView1.Columns[0].HeaderText = "No"; dataGridView1.Columns[1].HeaderText = "サイト名"; dataGridView1.Columns[2].HeaderText = "ログインIDまたはEmail等"; dataGridView1.Columns[3].HeaderText = "パスワード"; dataGridView1.Columns[4].HeaderText = "登録日"; dataGridView1.Columns[5].HeaderText = "備考"; trans.Commit(); cn.Close(); //行の幅を自動で調整する dataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells; } } } } /// <summary> /// /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void dataGridView1_Validating(object sender, CancelEventArgs e) { } private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e) { //DataGridViewの内容をコピー Clipboard.SetDataObject(dataGridView1.GetClipboardContent()); } private void Itiran_Load(object sender, EventArgs e) { } private void Itiran_KeyDown(object sender, KeyEventArgs e) { //Enterキーでコントロール遷移 if (e.KeyCode == Keys.Enter) { if (e.Shift) { ProcessTabKey(false); } else { ProcessTabKey(true); } } } } }

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

YAmaGNZ
YAmaGNZ

2017/02/14 11:08

DataGridViewからのみ削除するのでしょうか?それともDBも一緒に削除するのでしょうか?
yamaguti
yamaguti

2017/02/14 13:54

DBにアップデートで論理削除しようと思います

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

C#

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