SQLiteSharp 3.0.0
dotnet add package SQLiteSharp --version 3.0.0
NuGet\Install-Package SQLiteSharp -Version 3.0.0
<PackageReference Include="SQLiteSharp" Version="3.0.0" />
paket add SQLiteSharp --version 3.0.0
#r "nuget: SQLiteSharp, 3.0.0"
// Install SQLiteSharp as a Cake Addin #addin nuget:?package=SQLiteSharp&version=3.0.0 // Install SQLiteSharp as a Cake Tool #tool nuget:?package=SQLiteSharp&version=3.0.0
SQLiteSharp
SQLiteSharp is a powerful library to help you access a SQLite database in C#.
<img src="https://github.com/Joy-less/SQLiteSharp/blob/main/Assets/SQLette%20Face.png?raw=true" width=220>
SQLette protecting your database schema from getting corrupted.
Features
- Create tables from your .NET objects
- Annotate members as primary keys, foreign keys, not null, unique, indexed and more
- Manage your database with No-SQL APIs
- Use synchronous and asynchronous functions
- Encrypt your database with SQLCipher
Background
This project was originally based on SQLite-net by Krueger Systems Inc.
SQLiteSharp is a complete rewrite of the original, providing a modern experience akin to MongoDB or LiteDB with the power of SQLite.
Example
First, declare your object with optional annotations:
public class ShopItem {
[PrimaryKey, AutoIncrement]
public long Id { get; set; }
[NotNull]
public string? ItemName { get; set; }
public long Count { get; set; }
[Ignore]
public int SomethingToIgnore { get; set; }
}
Second, open a connection to your database:
// Open a database connection
using SQLiteConnection Connection = new("database.db");
// Create a table for a class
SqliteTable<ShopItem> ShopItems = Connection.GetTable<ShopItem>();
// Delete all existing items in the table
ShopItems.DeleteAll();
// Insert items into the table
ShopItems.Insert(new ShopItem() {
ItemName = "Apple",
Count = 10,
});
ShopItems.Insert(new ShopItem() {
ItemName = "Banana",
Count = 5,
});
// Find one item in the table matching a predicate
ShopItem? Apple = Connection.Find<ShopItem>(ShopItem => ShopItem.ItemName == "Apple");
// Delete an item from the table
ShopItems.DeleteByKey(Apple.Id);
// Find several items in the table
List<ShopItem> Bananas = ShopItems.Find(ShopItem => ShopItem.ItemName == "Banana").ToList();
Custom Type Serialization
SQLiteSharp supports serialization for a set of common types.
Polymorphism is supported, so you can register object
as a fallback for all missing types.
By default, unregistered types are serialized as JSON using System.Text.Json
.
public class SweetWrapper {
public Sweet? Sweet { get; set; } // custom type
}
public class Sweet(string Flavour) {
public string? Flavour { get; set; } = Flavour;
}
// Open a database connection
using SQLiteConnection Connection = new(":memory:");
// Register custom type
Connection.Orm.RegisterType<Sweet>(
SqliteType.Text,
serialize: (Sweet Sweet) => JsonSerializer.Serialize(Sweet),
deserialize: (SqliteValue Value, Type ClrType) => (Sweet?)JsonSerializer.Deserialize(Value.CastText, ClrType)
);
Tips
Automatic Schema Migration
Tables are automatically migrated to add new tables and columns, however existing columns are not modified.
Thread Safety
A SqliteConnection should not be used by multiple threads. However, multiple SqliteConnections can be opened and used concurrently, since they use SQLite's built-in FullMutex
.
Versioning Guide
SQLiteSharp uses versions like "1.0" and "2.4".
For developers:
- Increment the major version when adding new features or making breaking changes.
- Increment the minor version when fixing bugs or making small improvements.
For users:
- You usually want the latest major version, although it may require some changes to your project.
- You always want the latest minor version, and there should not be any issues upgrading.
SQLette
<img src="https://github.com/Joy-less/SQLiteSharp/blob/main/Assets/SQLette.png?raw=true" width=512>
Created with FurryToonMixV2
Origin Story
Born within the infinite digital expanse of the Great Data Plane, SQLette (スキレット) was created by the ancient Architects to oversee the seamless flow of information across interconnected worlds. Known as the Keeper of Queries, she was endowed with the ability to navigate and organize endless streams of data, ensuring balance and order within the fragmented realms. However, a catastrophic event known as the SQL Injection threatened to disrupt the harmony, causing data anomalies and erasing vital records. With her trusty artifact, the Schema Scepter, and a holographic tablet that manifests the Key of Relations, SQLette set out on a journey to restore the lost tables and normalize the anomalies.
Interview
SQLette's guest appearance on Pixelated Hearts!:
Host: Welcome back to Pixelated Hearts! Today, we have a very special guest: the keeper of queries herself, SQLette! How are you doing today, SQLette?
SQLette: Oh, I'm doing great! Just finished normalizing a table... now everything's perfectly indexed!
Host: Wow, I'm glad to hear it! So, I've heard you've been dealing with some pretty intense problems like the SQL Injection. What's that like for you?
SQLette: Oh, it's such a hassle. Imagine someone trying to sneak in and mess with your precious queries! I just sit there, go "Nope!", and block them. But sometimes I have to clear up a lot of corrupted data...
Host: Sounds stressful! What's your secret to staying so composed?
SQLette: Oh, simple! I just index my emotions and keep everything in its proper table. Oh, and caffeine. I've got a huge database of coffee preferences!
Host: That's the key to success, huh? Last question - if you could give one piece of advice to our viewers, what would it be?
SQLette: Oh, easy! Don't forget to backup your data. Life's unpredictable, and you never know when you'll face a rollback!
Host: That's some solid advice! Thanks for joining us, SQLette! We'll be sure to keep our tables in order!
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- PolySharp (>= 1.15.0)
- SQLitePCLRaw.bundle_e_sqlcipher (>= 2.1.10)
- System.Linq.Async (>= 6.0.1)
- System.Text.Json (>= 9.0.1)
-
.NETStandard 2.1
- SQLitePCLRaw.bundle_e_sqlcipher (>= 2.1.10)
- System.Linq.Async (>= 6.0.1)
- System.Text.Json (>= 9.0.1)
-
net8.0
- SQLitePCLRaw.bundle_e_sqlcipher (>= 2.1.10)
- System.Linq.Async (>= 6.0.1)
- System.Text.Json (>= 9.0.1)
-
net9.0
- SQLitePCLRaw.bundle_e_sqlcipher (>= 2.1.10)
- System.Linq.Async (>= 6.0.1)
- System.Text.Json (>= 9.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.