Visual C#で、DataGridViewにデータを表示させてみようと思います。
テーブルを選択させて、そのテーブルの中身を表示させるような感じで。。
■かんたんに解説
~49行目:以前の記事とほとんど同じです。
※48行のみ少し異なりますが、コンボボックスにテーブル名を入れている感じになります。
59~62行目:このあたりが表示させるための処理でしょうか、なんとなくしか分からないけど。。
SQLiteDataAdapterでテーブルに繋ぎにいって、dataTableにテーブルの中身つっこんで
DataGridViewのデータソースをdataTableにすると表示できますよって感じなんですかね
■サンプルコード
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
using System; using System.Data; using System.Data.SQLite; using System.Windows.Forms; namespace WindowsFormsApp1 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { using (var conn = new SQLiteConnection("Data Source = testDB")) { conn.Open(); using (SQLiteCommand command = conn.CreateCommand()) { command.CommandText = "CREATE TABLE SAMPLE1(Fish TEXT)"; command.ExecuteNonQuery(); command.CommandText = "CREATE TABLE SAMPLE2(Meat TEXT)"; command.ExecuteNonQuery(); command.CommandText = "CREATE TABLE SAMPLE3(Vegetables TEXT)"; command.ExecuteNonQuery(); } } } private void button2_Click(object sender, EventArgs e) { using (var conn = new SQLiteConnection("Data Source = testDB")) { conn.Open(); using (SQLiteCommand command = conn.CreateCommand()) { command.CommandText = "SELECT * FROM sqlite_master"; using (SQLiteDataReader reader = command.ExecuteReader()) { while (reader.Read()) { table.Items.Add(reader["name"] as string); } } } } } private void table_SelectedIndexChanged(object sender, EventArgs e) { DataTable dataTable = new DataTable(); dataTable.Clear(); using (var conn = new SQLiteConnection("Data Source = testDB")) { conn.Open(); SQLiteDataAdapter adapter = new SQLiteDataAdapter("SELECT * FROM " + table.Text + ";", conn); adapter.Fill(dataTable); dataGridView.DataSource = dataTable; } } } } |
コメントを残す