python导入到mysql设置主键_Python3 操作 MySQL 插入一条数据并返回主键 id的实例

  • Post author:
  • Post category:mysql

Python3 操作 MySQL 插入一条数据并返回主键 id的实例

发布时间:2020-08-29 11:39:47

来源:脚本之家

阅读:110

作者:极客点儿

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方法前插入以下代码即可:

SELECT LAST_INSERT_ID() AS id

以上这篇Python3 操作 MySQL 插入一条数据并返回主键 id的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持亿速云。


版权声明:本文为weixin_39624700原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。