Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/perfectlysoft/perfect-sqlite
A stand-alone Swift wrapper around the SQLite 3 client library.
https://github.com/perfectlysoft/perfect-sqlite
database perfect server-side-swift sqlite sqlite3 swift
Last synced: about 2 months ago
JSON representation
A stand-alone Swift wrapper around the SQLite 3 client library.
- Host: GitHub
- URL: https://github.com/perfectlysoft/perfect-sqlite
- Owner: PerfectlySoft
- License: apache-2.0
- Created: 2016-04-04T15:02:34.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-05-18T18:27:31.000Z (over 2 years ago)
- Last Synced: 2024-10-27T06:38:53.488Z (2 months ago)
- Topics: database, perfect, server-side-swift, sqlite, sqlite3, swift
- Language: Swift
- Homepage: https://www.perfect.org
- Size: 206 KB
- Stars: 49
- Watchers: 6
- Forks: 19
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Perfect - SQLite Connector
This project provides a Swift wrapper around the SQLite 3 library.
This package builds with Swift Package Manager and is part of the [Perfect](https://github.com/PerfectlySoft/Perfect) project. It was written to be stand-alone and so does not require PerfectLib or any other components.
Ensure you have installed and activated the latest Swift 4.0 tool chain.
To learn more, you can read the full documentation guide [here](https://github.com/PerfectlySoft/PerfectDocs/blob/master/guide/SQLite.md) or jump to the example [here](#Usage-Example)
## Linux Build Notes
Ensure that you have installed sqlite3.
```
sudo apt-get install sqlite3
```## Building
Add this project as a dependency in your Package.swift file.
```
.Package(url: "https://github.com/PerfectlySoft/Perfect-SQLite.git", majorVersion: 3)
```### Edge Case
If you encounter error like such ``` sqlite3.h file not found ``` during ```$ swift build ```, one solution is to install the sqlite3-dev i.e. ```$ sudo apt-get install libsqlite3-dev```## Usage Example
Let’s assume you’d like to host a blog in Swift. First we need tables. Assuming you’ve created an SQLite file `./db/database`, we simply need to connect and add the tables.
```swift
let dbPath = "./db/database"do {
let sqlite = try SQLite(dbPath)
defer {
sqlite.close()
}try sqlite.execute(statement: "CREATE TABLE IF NOT EXISTS posts (id INTEGER PRIMARY KEY NOT NULL, post_title TEXT NOT NULL, post_content TEXT NOT NULL, featured_image_uri TEXT NOT NULL)")
} catch {
print("Failure creating database tables") //Handle Errors
}
```Next, we would need to add some content.
```swift
let dbPath = "./db/database"
let postTitle = "Test Title"
let postContent = "Lorem ipsum dolor sit amet…"do {
let sqlite = try SQLite(dbPath)
defer {
sqlite.close()
}try sqlite.execute(statement: "INSERT INTO posts (post_title, post_content) VALUES (:1,:2)") {
(stmt:SQLiteStmt) -> () intry stmt.bind(position: 1, postTitle)
try stmt.bind(position: 2, postContent)
}
} catch {
//Handle Errors
}
```Finally, we retrieve posts and post titles from an SQLite database full of blog content. Each id, post, and title is appended to a dictionary for use elsewhere.
``` swift
let dbPath = "./db/database"
var contentDict = [String: Any]()do {
let sqlite = try SQLite(dbPath)
defer {
sqlite.close() // This makes sure we close our connection.
}
let demoStatement = "SELECT post_title, post_content FROM posts ORDER BY id DESC LIMIT :1"
try sqlite.forEachRow(statement: demoStatement, doBindings: {
(statement: SQLiteStmt) -> () in
let bindValue = 5
try statement.bind(position: 1, bindValue)
}) {(statement: SQLiteStmt, i:Int) -> () inself.contentDict.append([
"id": statement.columnText(position: 0),
"second_field": statement.columnText(position: 1),
"third_field": statement.columnText(position: 2)
])
}
} catch {
//Handle Errors
}
```## Further Information
For more information on the Perfect project, please visit [perfect.org](http://www.perfect.org/docs/SQLite.html).