如何在 SWIFT 中的 sqlite table 中添加列

how to add column in a sqlite table in SWIFT

我尝试用 swift 在 table 中添加一列。

我的代码:

  connect_db();
  adddbfield("mynewfield","mytable");

.

func connect_db() -> Bool {
    let sDBPath=<is correctly set>;
    if sqlite3_open(sDBPath, &db) != SQLITE_OK {
        println("Failed to open db")
        return false;
    }else{
        return true;
    }
}

.

func adddbfield(sFieldName:String, sTable:String) -> Bool {
    var bReturn:Bool=false;
    var sSQL="ALTER TABLE " + sTable + " ADD COLUMN " + sFieldName + " INTEGER DEFAULT -1";
    var statement:COpaquePointer = nil
    if sqlite3_prepare_v2(db, sSQL, -1, &statement, nil) != SQLITE_OK {
        println("Failed to prepare statement")
    }else{
        println("field " + sFieldName + " added  to  " + sTable);
        bReturn=true;
    }
    return bReturn;
}

使用此代码,不会添加任何字段,也不会发生错误。 有什么帮助吗? (我想使用对 sqlite 的本地访问,而不需要额外的库)

您只是在准备声明,而不是执行它。您需要调用 sqlite3_step()sqlite3_finalize() 方法来完成该过程。

func adddbfield(sFieldName:String, sTable:String) -> Bool
{
    var bReturn:Bool = false;
    var sSQL="ALTER TABLE " + sTable + " ADD COLUMN " + sFieldName + " INTEGER DEFAULT -1";
    var statement:COpaquePointer = nil
    if sqlite3_prepare_v2(db, sSQL, -1, &statement, nil) != SQLITE_OK
    {
        println("Failed to prepare statement")
    }
    else
    {
        if sqlite3_step(statement) == SQLITE_DONE
        {
           println("field " + sFieldName + " added  to  " + sTable);
        }
        sqlite3_finalize(statement);
        bReturn=true;
    }
    return bReturn;
}