您好,登錄后才能下訂單哦!
Python 中貌似并沒有直接返回插入數據 id 的操作(反正我是沒找到),但是我們可以變通一下,找到最新插入的數據
#!/usr/bin/env python3 # -*- coding: UTF-8 -*- import pymysql db = pymysql.connect(**db_conf) cursor = db.cursor() cursor.execute(sql) # 最后插入行的主鍵id print(cursor.lastrowid) # 最新插入行的主鍵id print(conn.insert_id()) conn.commit()
使用 cursor.lastrowid 和 conn.insert_id() 時一定要在 conn.commit() 之前
由于數據庫的安全機制決定,其中一個進程執行完成一條語句時,此時只有這個進程能看到數據。如果想要其他的進程也能看到數據,就需要使用 conn.commit() 提交,這樣就保證了多進程同時操作數據庫而不會沖突
但是多線程并發插入的時候就不行了,因為多線程是共享數據的,而且在 Python 中并沒有所謂的真正多線程,建議使用多進程
補充拓展:mysql中插入一條數據后得到插入后的主鍵id值
** 當我們涉及多表進行插入操作是,常常需要在程序中等到剛剛插入數據的主鍵Id,
便與進行多表關聯 **
那么便需要在*Mapper.xml的insert方法前插入以下代碼即可:
<selectKey resultType="java.lang.Long" order="AFTER" keyProperty="id"> SELECT LAST_INSERT_ID() AS id </selectKey>
以上這篇Python3 操作 MySQL 插入一條數據并返回主鍵 id的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。