Fehlervorbereitung: Ungültiger Parameter oder anderer API-Missbrauch in SQLite Swift beim Einfügen von DatenIOS

Programmierung für iOS
Anonymous
 Fehlervorbereitung: Ungültiger Parameter oder anderer API-Missbrauch in SQLite Swift beim Einfügen von Daten

Post by Anonymous »

Code: Select all

let db = Database.openDatabase()

let insertStatementString = "INSERT INTO SignupDetails VALUES (\((self.txtUsername.text!.trimmingCharacters(in: .whitespaces))), \((self.txtPassword.text!.trimmingCharacters(in: .whitespaces))))"

Database.insertIntoSignupDetails(db: db, insertStatementString: insertStatementString)

sqlite3_close(db)
Der obige Code enthält meine Abfrage zum Einfügen von Daten in die Datenbank mit SQLite.

Ich habe eine Tabelle wie unten gezeigt erstellt:-

Code: Select all

let db = Database.openDatabase()
let createTableString =
"""
CREATE TABLE IF NOT EXISTS SignupDetails(
username CHAR(255),
password CHAR(255));
"""

Database.createTable(db: (db != nil) ? db : OpaquePointer(UserDefaults.standard.object(forKey: Constant.db) as! String), createTableString: createTableString)

sqlite3_close(db)
und ich habe auch den folgenden Code für die Tabellenerstellung erfolgreich ausgeführt:-

Code: Select all

static func createTable(db: OpaquePointer?, createTableString: String) {
var createTableStatement: OpaquePointer? = nil

if sqlite3_prepare_v2(db, createTableString, -1, &createTableStatement, nil) == SQLITE_OK {
if sqlite3_step(createTableStatement) == SQLITE_DONE {
print("table created.")
} else {
print("table could not be created.")
}
} else {
print("CREATE TABLE statement could not be prepared.")
}

sqlite3_finalize(createTableStatement)
}
Aber mein Problem ist, wenn ich versuche, Daten in die vorhandene Tabelle einzufügen

die folgende Fehlermeldung angezeigt wird:-

Code:-

Code: Select all

    var insertStatement: OpaquePointer?

guard sqlite3_prepare_v2(db, insertStatementString, -1, &insertStatement, nil) == SQLITE_OK else {
let errmsg = String(cString: sqlite3_errmsg(db))
print("failure preparing: \(errmsg)")
return
}

if sqlite3_step(insertStatement) == SQLITE_OK {
print("Successfully inserted row.")
} else {
print("Could not insert row.")
}

sqlite3_finalize(insertStatement)
Fehler:-

Fehler bei der Vorbereitung: fehlerhafter Parameter oder anderer API-Missbrauch

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post