This package provides the excelent SQLite-net library for accessing SQLite databases in Unity.
- SQLite-net v1.8.116
- Both synchronous and asynchronous APIs are available
SQLiteConnection.Serialize
extension method for serializing a database tobyte[]
(reference: SQLite Serialization).SQLiteConnection.Deserialize
extension method for deserializing memory (byte[]
,NativeArray<byte>
orReadOnlySpan<byte>
) into an open database (reference: SQLite Deserialization).
- SQLite 3.46.1
- Enabled modules: R*Tree, Geopoly, FTS5, Built-In Math Functions
- Prebuilt for Windows, Linux, macOS, Android and WebGL
- Built from source in iOS, tvOS and visionOS projects
- Supports persisting data in WebGL builds by using a custom VFS backed by Indexed DB.
- SQLite Asset: read-only SQLite database assets for Unity with scripted importer for ".sqlite", ".sqlite2" and ".sqlite3" files
- SQLite Asset - CSV: easily import ".csv" files as read-only SQLite database assets
Either:
- Use the openupm registry and install this package using the openupm-cli:
openupm add com.gilzoide.sqlite-net
- Install using the Unity Package Manager with the following URL:
https://github.com/gilzoide/unity-sqlite-net.git#1.1.2
- Clone this repository or download a snapshot of it directly inside your project's
Assets
orPackages
folder.
The following code demonstrates some of SQLite-net's core functionality. Check out SQLite-net's Wiki for more complete documentation on how to use the library.
using SQLite;
using UnityEngine;
// The library contains simple attributes that you can use
// to control the construction of tables, ORM style
public class Player
{
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
public string Name { get; set; }
}
public class TestSQLite : MonoBehaviour
{
void Start()
{
// 1. Create a connection to the database.
// The special ":memory:" in-memory database and
// URIs like "file:///somefile" are also supported
var db = new SQLiteConnection($"{Application.persistentDataPath}/MyDb.db");
// 2. Once you have defined your entity, you can automatically
// generate tables in your database by calling CreateTable
db.CreateTable<Player>();
// 3. You can insert rows in the database using Insert
// The Insert call fills Id, which is marked with [AutoIncremented]
var newPlayer = new Player
{
Name = "gilzoide",
};
db.Insert(newPlayer);
Debug.Log($"Player new ID: {newPlayer.Id}");
// Similar methods exist for Update and Delete.
// 4.a The most straightforward way to query for data
// is using the Table method. This can take predicates
// for constraining via WHERE clauses and/or adding ORDER BY clauses
var query = db.Table<Player>().Where(p => p.Name.StartsWith("g"));
foreach (Player player in query)
{
Debug.Log($"Found player named {player.Name} with ID {player.Id}");
}
// 4.b You can also make queries at a low-level using the Query method
var players = db.Query<Player>("SELECT * FROM Player WHERE Id = ?", 1);
foreach (Player player in players)
{
Debug.Log($"Player with ID 1 is called {player.Name}");
}
// 5. You can perform low-level updates to the database using the Execute
// method, for example for running PRAGMAs or VACUUM
db.Execute("VACUUM");
}
}
SQLite-net for Unity first-party code is licensed under the MIT license.
Third-party code:
- SQLite-net: MIT license
- SQLite: public domain
- The value of
LibraryPath
was changed fromsqlite3
to__Internal
in WebGL/iOS/tvOS/visionOS builds andgilzoide-sqlite-net
for other platforms. This makes sure the prebuilt libraries are used instead of the ones provided by the system. LibraryPath
is made public. This is useful for libraries that want to bind additional native SQLite functions via P/Invoke.SQLiteConnection.Quote
is made public. This is be useful for libraries making raw queries.SQLite3.SetDirectory
is only defined in Windows platforms.- Adds a
[RequiredMember]
attribute toColumnInfo.Name
property, fixing errors on columns when managed code stripping is enabled. - Changes the
TaskScheduler
used by the async API on WebGL to one that executes tasks on Unity's main thread.