1

我是 iOS 开发的初学者,我想在我的应用程序中开发一个数据库。但是,当我尝试创建数据库时,它说无法打开数据库文件

在此处输入图像描述

为澄清(https://github.com/stephencelis/SQLite.swift/blob/master/Documentation/Index.md

在此处输入图像描述

我的数据库开发代码如下

static func DB(){

        do {
            let db = try Connection("db.sqlite3")
            let users = Table("users")
            let id = Expression<Int64>("id")
            let name = Expression<String?>("name")
            let email = Expression<String>("email")

            try db.run(users.create { t in
                t.column(id, primaryKey: true)
                t.column(name)
                t.column(email, unique: true)
                })

        } catch {
            print("Dim background error")
        }
}

我从应用程序委托文件触发此方法

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
        // Override point for customization after application launch.

        AppCommon.DB()

        return true
    }

如何解决这个问题?请帮帮我,我真的需要你的帮助..!

4

2 回答 2

3

在 iOS 上,您无法在所需的位置创建文件。正确的位置(除其他外)在文档目录中。

引用您正在使用的库的文档https://github.com/stephencelis/SQLite.swift/blob/master/Documentation/Index.md#connecting-to-a-database

在 iOS 上,您可以在应用的 Documents 目录中创建可写数据库。

let path = NSSearchPathForDirectoriesInDomains(
   .DocumentDirectory, .UserDomainMask, true
).first!

let db = try Connection("\(path)/db.sqlite3")
于 2016-01-10T17:24:29.857 回答
0

斯威夫特 5

文档目录的路径现在是一个字符串数组

let path = NSSearchPathForDirectoriesInDomains(
                .documentDirectory, .userDomainMask, true)
let db = try Connection("\(path.first ?? "")/db.sqlite3")
于 2021-12-29T03:15:46.833 回答