info = "'INSERT INTO brush_card_record(brush_card_date, brush_card_time, card_num_6061, card_num_6654) VALUES(?,?,?,?)',('2017-05-28','12:23:32?)',('2017-05-28','12:23:32' 0)"
cur.execute(info)
這樣會報錯:sqlite3.OperationalError
cur.execute('INSERT INTO brush_card_record(brush_card_date, brush_card_time, card_num_6061, card_num_6654) VALUES(?,?,?,?)',('2017-05-28','12:?,?,?)',('2017-05-28','12:23:233 , 0))
這樣就可以運行。
cur.execute有兩個參數,一個是SQL,一個是給SQL的參數傳值,你第一句用雙引號括起來相當一個字串,也就是一個參數,沒有傳入第二個參數
info =“插入brush_card_record(brush_card_date,brush_card_time,card_num_6061,card_num_6654)值(%s,%s,%s,%s)”%('2017-05-28','12:23:32',123,',12:23:32',123,' 0)
或str.format
雷雷
問題已找到,謝謝回答的朋友!
資料庫表插入新資料為動態時,較好的處理方式是先生成str,然後作為參數傳進cur.execute()。
程式碼範例: