postgresql在插入数据后怎么获取自增id
要获取数据库自动分配的ID(通常是主键),可以使用数据库连接对象(在这里是 Connection
)的相应方法来获取插入的最后一个自增ID。
不同的数据库管理系统有不同的方法来实现这一点。以下是两个常见的数据库管理系统的示例:
对于 PostgreSQL
如果你使用的是 PostgreSQL 数据库,可以使用 RETURNING
子句来返回插入的行的信息,包括自动生成的ID。以下是一个示例:
sqlStr = """
INSERT INTO charts (name, file_name, scale,)
VALUES (%(name)s, %(fileName)s, %(scale)s)
RETURNING id;
"""
Cursor.execute(sqlStr, chartsInfo)
inserted_id = Cursor.fetchone()[0] # 获取自增ID
Connection.commit()
print('插入成功!新记录的ID为:', inserted_id)
这个示例中,我们在 SQL 查询中使用 RETURNING id;
来返回插入的新记录的ID,然后使用 self._Cursor.fetchone()[0]
获取这个ID。
对于 MySQL
如果使用的是 MySQL 数据库,可以使用 LAST_INSERT_ID()
函数来获取最后插入的自增ID。以下是一个示例:
sqlStr = """
INSERT INTO charts (name, file_name, scale)
VALUES (%(name)s, %(fileName)s, %(scale)s);
"""
Cursor.execute(sqlStr, chartsInfo)
Connection.commit()
inserted_id = Cursor.lastrowid # 获取自增ID
print('插入成功!新记录的ID为:', inserted_id)
在这个示例中,我们插入了数据,然后使用 Cursor.lastrowid
获取最后插入的自增ID。
具体的方法取决于所使用的数据库管理系统,因此请根据数据库类型选择适当的方法。
在这两个示例中,演示了如何在 PostgreSQL 和 MySQL 中获取自增ID。
分类:
SQL / PostgreSQL
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
2022-09-03 geoserver如何配置图层样式(SLD格式)
2022-09-03 geoserver配置线图层样式(QGIS版的SLD格式)