へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
SQLite
›
EF Core で SQLite に配列を格納する
2019/04/02
EF Core で SQLite に配列を格納する
update
event_note
label
Entity Framework Core
label
SQLite
DB に配列を格納することの是非はさておき、EntityFramework Core を使って SQLite に配列を格納する方法です。
## 環境 - Visual Studio 2017 - .NET Core 2.2 ## モデル イメージとして、以下のような `int` の配列を持つオブジェクトを DB に格納したいとします。 ```cs public class PersonDbContext : DbContext { public DbSet
Persons { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { optionsBuilder.UseSqlite("Data Source=sqlitetest.db"); } } public class Person { public int Id { get; set; } public string Name { get; set; } public int[] Attributes { get; set; } } ``` しかし、このままビルドすると以下のようなエラーが表示されます。 > System.InvalidOperationException: 'The property 'Person.Attributes' could not be mapped, because it is of type 'Int32[]' which is not a supported primitive type or a valid entity type. Either explicitly map this property, or ignore it using the '[NotMapped]' attribute or by using 'EntityTypeBuilder.Ignore' in 'OnModelCreating'.' ## 配列を保存するためには DB には配列を文字列として格納し、取り出すときに分割して `int` に変換するようにします。 先ほどのコードを以下のように変更します。 ```cs public class PersonDbContext : DbContext { public DbSet
Persons { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { optionsBuilder.UseSqlite("Data Source=sqlitetest.db"); } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity
() .Property
("AttributeCollection") .HasField("_attributes"); } } public class Person { private static readonly char delimiter = ';'; public int Id { get; set; } public string Name { get; set; } string _attributes; [NotMapped] public int[] Attributes { get => _attributes.Split(delimiter).Select(x => int.Parse(x)).ToArray(); set => _attributes = string.Join(delimiter, value); } } ``` `int[] Attributes` には `NotMapped` 属性を付与することで、O/R マッパーの対象から外します。 その代わりに `string _attributes` というフィールドを用意し、`int[] Attributes` のプロパティで、`_attributes` に対する `get` と `set` を用意します。 `int` 配列と文字列の変換には、デリミターとして `;` を使用しています。 `DbContext` クラスの `OnModelCreating` メソッドでは、`_attributes` フィールドに `AttributeCollection` というプロパティを割り当てるように設定しています。 以上で、`Person` クラスを使う側からは DB を意識せずに配列を扱うことができます。 ```cs using (var db = new PersonDbContext()) { var person = new Person { Name = name, Attributes = new int[] { 0, 1, 2 } }; db.Persons.Add(person); db.SaveChanges(); } ``` ```cs using (var db = new PersonDbContext()) { foreach (var person in db.Persons) { Console.WriteLine($"ID = {person.Id}, Name = {person.Name}, Attributes={string.Join(", ", person.Attributes)}"); } } ``` DB Browser for SQLite で中身を見ると、文字列として格納されているのがわかります。
## 参考 URL - https://kimsereyblog.blogspot.com/2017/12/save-array-of-string-entityframework.html
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
82
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
3
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
2
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(21)
►
12月
(3)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
►
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
▼
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
▼
4月
(17)
[ASP.NET Core] ブラウザによってはセッションの状態が保存されない
[C#] Linq の First と Single の挙動
[C#] nameof と ToString の違い
[ASP.NET Core] Post メソッドで配列やリストを渡す
[C#] 並びを反転させる Reverse について
[C#] Dictionary の キーがタプルの場合に JSON へのシリアライズとデシリアライズ...
Pine Script の参考サイト
AWS Cloud9 で ASP.NET Core を使う
DokuWiki で Markdown を使えるようにする
DokuWiki でユーザーのみ記事の編集ができるようにする
DokuWiki で LDAP 認証 (Active Directory 連携) を行う
DokuWiki を docker-compose で動かしてみる
[C#] DateTime の不要な桁を切り捨てる拡張メソッド
Cannot consume scoped service from singleton
GitLab の Pipeline をデフォルトで無効にする
[C#] Null 条件演算子いろいろ
EF Core で SQLite に配列を格納する
►
3月
(9)
►
2月
(6)
►
1月
(8)
►
2018
(100)
►
12月
(1)
►
11月
(11)
►
10月
(8)
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)