[C#]SQLiteでのデータSELECT方法とは?主キー、LINQ、SQLによるデータSELECT
- システム
エンジニア - 今回はデータSELECT方法について教えてください。
- プロジェクト
マネージャー - 分かりました。ここではSQLiteを利用したデータSELECT方法についてみていきましょう。
[C#]SQLiteでのデータSELECT方法とは?
今回は、C#でのSQLiteを利用したデータSELECT方法について説明します。ここでは、全データSELECT、主キーによるデータSELECT、LINQによるデータSELECT、SQLによるデータSELECTについて紹介します。
C#でのSQLiteを利用したデータSELECT方法に興味のある方はぜひご覧ください。
全データSELECT
C#でのSQLiteを利用した全データのSELECT方法を紹介します。実際のソースコードを見てみましょう。
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
|
using SQLite;
using System;
namespace ConsoleApplication1
{
class Program
{
public class User
{
public User() { }
public User(string Name, int Age)
{
this.Name = Name;
this.Age = Age;
}
[AutoIncrement, PrimaryKey]
public int Id { get; set; } // 主キー
public string Name { get; set; } // 名前
public int Age { get; set; } // 年齢
}
public static void Main()
{
// データベースへ接続
using (var connection = new SQLiteConnection(@"C:\test\SQLiteTest.db"))
{
// テーブルの作成(あればスキップ)
connection.CreateTable<User>();
// データ数が0件の場合
if (connection.Table<User>().Count() == 0)
{
// データINSERT
connection.Insert(new User("taro", 42));
connection.Insert(new User("jiro", 23));
connection.Insert(new User("hanako", 31));
}
// 全データSELECT
var userList = connection.Table<User>();
foreach (User user in userList)
{
Console.WriteLine("Id:{0}, Name:{1}, Age:{2}", user.Id, user.Name, user.Age);
}
}
}
}
}
|
実行結果は以下のようになります。
1
2
3
|
Id:1, Name:taro, Age:42
Id:2, Name:jiro, Age:23
Id:3, Name:hanako, Age:31
|
主キーによるデータSELECT
C#での主キーによるデータSELECT方法を紹介します。実際のソースコードを見てみましょう。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
// データベースへ接続
using (var connection = new SQLiteConnection(@"C:\test\SQLiteTest.db"))
{
// テーブルの作成(あればスキップ)
connection.CreateTable<User>();
// データ数が0件の場合
if (connection.Table<User>().Count() == 0)
{
// データINSERT
connection.Insert(new User("taro", 42));
connection.Insert(new User("jiro", 23));
connection.Insert(new User("hanako", 31));
}
// 主キーによるデータSELECT
var user = connection.Get<User>(2);
Console.WriteLine("Id:{0}, Name:{1}, Age:{2}", user.Id, user.Name, user.Age);
}
|
実行結果は以下のようになります。
1
|
Id:2, Name:jiro, Age:23
|
このようにC#では、主キーによるデータSELECTができます。
LINQによるデータSELECT
C#でのLINQによるデータSELECT方法を紹介します。実際のソースコードを見てみましょう。
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
|
using (var connection = new SQLiteConnection(@"C:\test\SQLiteTest.db"))
{
// テーブルの作成(あればスキップ)
connection.CreateTable<User>();
// データ数が0件の場合
if (connection.Table<User>().Count() == 0)
{
// データINSERT
connection.Insert(new User("taro", 42));
connection.Insert(new User("jiro", 23));
connection.Insert(new User("hanako", 31));
}
// データSELECT(Id指定)
var userList = from s in connection.Table<User>()
where s.Id == 3
select s;
foreach (User u in userList)
{
Console.WriteLine("Id=3 Id:{0}, Name:{1}, Age:{2}", u.Id, u.Name, u.Age);
}
// データSELECT(Nameにaを含む)
userList = from s in connection.Table<User>()
where s.Name.Contains("a")
select s;
foreach (User u in userList)
{
Console.WriteLine("Contains(a) Id:{0}, Name:{1}, Age:{2}", u.Id, u.Name, u.Age);
}
// データSELECT(Ageが20以上かつ40以下)
userList = from s in connection.Table<User>()
where s.Age >= 20 && s.Age <= 40
select s;
foreach (User u in userList)
{
Console.WriteLine("20 <= age <= 40 Id:{0}, Name:{1}, Age:{2}", u.Id, u.Name, u.Age);
}
}
|
実行結果は以下のようになります。
1
2
3
4
5
|
Id=3 Id:3, Name:hanako, Age:31
Contains(a) Id:1, Name:taro, Age:42
Contains(a) Id:3, Name:hanako, Age:31
20 <= age <= 40 Id:2, Name:jiro, Age:23
20 <= age <= 40 Id:3, Name:hanako, Age:31
|
このようにC#では、LINQによるデータSELECTができます。
SQLによるデータSELECT
C#でのSQLによるデータSELECT方法を紹介します。実際のソースコードを見てみましょう。
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
|
// データベースへ接続
using (var connection = new SQLiteConnection(@"C:\test\SQLiteTest.db"))
{
// テーブルの作成(あればスキップ)
connection.CreateTable<User>();
// データ数が0件の場合
if (connection.Table<User>().Count() == 0)
{
// データINSERT
connection.Insert(new User("taro", 42));
connection.Insert(new User("jiro", 23));
connection.Insert(new User("hanako", 31));
}
// データSELECT(Id指定)
var userList = connection.Query<User>("SELECT * FROM User WHERE Id = ?", 3);
foreach (User user in userList)
{
Console.WriteLine("Id:{0}, Name:{1}, Age:{2}", user.Id, user.Name, user.Age);
}
// データSELECT(LIKE検索)
userList = connection.Query<User>("SELECT * FROM User WHERE Name LIKE '%a%'");
foreach (User user in userList)
{
Console.WriteLine("Id:{0}, Name:{1}, Age:{2}", user.Id, user.Name, user.Age);
}
}
|
実行結果は以下のようになります。
1
2
3
|
Id:3, Name:hanako, Age:31
Id:1, Name:taro, Age:42
Id:3, Name:hanako, Age:31
|
このようにC#では、SQLによるデータSELECTができます。
- システム
エンジニア - もし、条件式を指定していなければどうなりますか?
- プロジェクト
マネージャー - その場合は、テーブルに含まれる全てのデータを取得します。
まとめ
いかがでしたでしょうか。C#でのSQLiteを利用したデータSELECT方法について説明しました。ここでは、全データSELECT、主キーによるデータSELECT、LINQによるデータSELECT、SQLによるデータSELECTについて紹介しました。
ぜひご自身でC#のソースコードを書いて、理解を深めてください。
FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
株式会社オープンアップシステムはこんな会社です
秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
数多くのエンジニアが集まります。
-
スマホアプリから業務系システムまで
スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。
-
充実した研修制度
毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。
-
資格取得を応援
スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。
-
東証プライム上場企業グループ
オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
株式会社オープンアップシステムに興味を持った方へ
株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。
C#新着案件New Job
-
システム開発/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(新宿駅) -
システム開発/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(新宿駅) -
デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円神奈川県横浜市(桜木町駅) -
デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円神奈川県横浜市(桜木町駅) -
基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(西新宿駅) -
基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(西新宿駅)