-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathChinookDatabase.cs
124 lines (102 loc) · 4.05 KB
/
ChinookDatabase.cs
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
using System;
using SQLite;
using SQLitePCL;
using SqlUsage.Helpers;
using SqlUsage.Models;
namespace SqlUsage
{
public class ChinookDatabase
{
private readonly SQLiteConnection connection;
public ChinookDatabase(string databaseFilePath)
{
connection = new SQLite.SQLiteConnection(databaseFilePath);
connection.Trace = true;
connection.Tracer = TraceSqlQuery;
connection.CreateTable<Artist>();
connection.CreateTable<Album>();
connection.CreateTable<Artist>();
}
private void TraceSqlQuery(string query)
{
Console.WriteLine("Execute SQLite Query: " + query);
}
private static readonly Dictionary<string, object> emptyParameters = new Dictionary<string, object>();
internal List<Album> GetAlbums_Mapped()
{
//const string query = $"SELECT AlbumId, Title, ArtistId FROM {nameof(Album)}";
const string query = $"SELECT * FROM {nameof(Album)}";
return SqlHelper.ExecuteCancellableQuery<Album>(connection, query, emptyParameters, MapAlbum, CancellationToken.None);
}
private Album MapAlbum(sqlite3_stmt statement)
{
var albumId = SQLite3.ColumnInt(statement, 0);
var title = SQLite3.ColumnString(statement, 1);
var artistId = SQLite3.ColumnInt(statement, 2);
return new Album()
{
AlbumId = albumId,
ArtistId = artistId,
Title = title
};
}
internal List<Album> GetAlbums_ORM()
{
return connection.Query<Album>($"SELECT * FROM {nameof(Album)}");
}
internal List<Artist> GetArtists_Mapped()
{
//const string query = $"SELECT ArtistId, Name FROM {nameof(Artist)}";
const string query = $"SELECT * FROM {nameof(Artist)}";
return SqlHelper.ExecuteCancellableQuery<Artist>(connection, query, emptyParameters, MapArtist, CancellationToken.None);
}
private Artist MapArtist(sqlite3_stmt statement)
{
var artistId = SQLite3.ColumnInt(statement, 0);
var name = SQLite3.ColumnString(statement, 1);
return new Artist()
{
ArtistId = artistId,
Name = name
};
}
internal List<Artist> GetArtists_ORM()
{
return connection.Query<Artist>($"SELECT * FROM {nameof(Artist)}");
}
internal List<Track> GetTracks_Mapped()
{
//const string query = $"SELECT TrackId, Name, AlbumId, MediaTypeId, GenreId, Composer, Milliseconds, Bytes, UnitPrice FROM {nameof(Track)}";
const string query = $"SELECT * FROM {nameof(Track)}";
return SqlHelper.ExecuteCancellableQuery<Track>(connection, query, emptyParameters, MapTrack, CancellationToken.None);
}
private Track MapTrack(sqlite3_stmt statement)
{
var TrackId = SQLite3.ColumnInt(statement, 0);
var Name = SQLite3.ColumnString(statement, 1);
var AlbumId = SQLite3.ColumnInt(statement, 2);
var MediaTypeId = SQLite3.ColumnInt(statement, 3);
var GenreId = SQLite3.ColumnInt(statement, 4);
var Composer = SQLite3.ColumnString(statement, 5);
var Milliseconds = SQLite3.ColumnInt(statement, 6);
var Bytes = SQLite3.ColumnInt(statement, 7);
var UnitPrice = SQLite3.ColumnDouble(statement, 8);
return new Track()
{
TrackId = TrackId,
Name = Name,
AlbumId = AlbumId,
MediaTypeId = MediaTypeId,
GenreId = GenreId,
Composer = Composer,
Milliseconds = Milliseconds,
Bytes = Bytes,
UnitPrice = UnitPrice,
};
}
internal List<Track> GetTracks_ORM()
{
return connection.Query<Track>($"SELECT * FROM {nameof(Track)}");
}
}
}