Образцы проектов IOS XCODE
Это примеры тестовых проектов, поэтому для правильной работы их имя должно быть litesync-test.
Это ограничение отсутствует на полных библиотеках.
Оболочка SQLite.swift
Есть 2 примера проектов, использующих оболочку SQLite.swift
Первый имеет простой интерфейс с использованием SQL:
try db.execute("CREATE TABLE IF NOT EXISTS Tasks (id INTEGER PRIMARY KEY, name TEXT, done INTEGER)") try db.run("INSERT INTO Tasks (name, done) VALUES (?,?)", name, Int(done!)) for row in try db.prepare("SELECT * FROM Tasks") { let id = row[0] as! Int64 let name = row[1] as! String let done = Int(row[2] as! Int64) print("id: \(id) name: \(name) done: \(done)") }
Второй пример использует объекты:
let tasks = Table("tasks")
let id = Expression
Родной интерфейс SQLite
Этот пример проекта использует собственный интерфейс SQLite
let queryString = "SELECT * FROM Tasks" var stmt:OpaquePointer? if sqlite3_prepare(db, queryString, -1, &stmt, nil) != SQLITE_OK{ let errmsg = String(cString: sqlite3_errmsg(db)!) print("error preparing statement: \(errmsg)") return } while(sqlite3_step(stmt) == SQLITE_ROW){ let id = sqlite3_column_int(stmt, 0) let name = String(cString: sqlite3_column_text(stmt, 1)!) let done = sqlite3_column_int(stmt, 2) print("id: \(id) name: \(name) done: \(done)") } sqlite3_finalize(stmt)
Инструкции
Для обоих проектов:
1 Установите модифицированную оболочку SQLite на компьютере
2 Запустите оболочку SQLite в качестве основного узла привязки к TCP-адресу
3 Измените адрес TCP для подключения к коду проекта
4 Создайте и запустите проект на симуляторе или устройстве
Чтобы открыть базу данных на основном узле, мы используем такую команду:
sqlite3 "file:test.db?node=primary&bind=tcp://0.0.0.0:1234"