当前位置: 首页 > news >正文

【Qt】QxORM无法删除和更改主键值为0的行,否则报错:invalid primary key

1、问题描述

使用 QxORM 删除或者更改数据库时,当主键值为 0 时,报错:

[QxOrm] invalid primary key

2、原因分析

2.1 源码分析

查找打印错误提示的代码:

#define QX_DAO_ERR_INVALID_PRIMARY_KEY       "[QxOrm] invalid primary key"
QSqlError IxDao_Helper::errInvalidId() 
{ return updateError(QX_DAO_ERR_INVALID_PRIMARY_KEY); }

分别在以下的方法中检查 ID 值是否有效

deleteById
fetchById
update

检查 ID 值是否有效的方法

if (! dao.isValidPrimaryKey(t)) { return dao.errInvalidId(); }

2.2 主键无效的判定原则

跟踪 isValidPrimaryKey 方法,最后调用模板函数及特例 is_valid_primary_key,源码如下,可见,当主键值为 0 或者为 i

http://www.dtcms.com/a/266978.html

相关文章:

  • Docker学习笔记:Docker网络
  • DotNetBrowser 2.27.14 版本发布啦!
  • Python 制作 pyd(Windows 平台的动态链接库)
  • 力扣:70. 爬楼梯
  • [Terence Tao访谈] 无限 | 关注模型 | 矢量场 | 策略性“作弊” | Lean
  • 【Prometheus 】通过 Pushgateway 上报指标数据
  • 408第三季part1 - 操作系统 - 输入输出管理
  • pyproject.toml 有什么作用呢?
  • Java对象哈希值深度解析
  • vue/微信小程序/h5 实现react的boundary
  • 汽车功能安全概念阶段开发【相关项定义HARA】2
  • 【Mysql系列】Mysql 多级隔离级别揭秘
  • 使用Python绘制图片拆分工具
  • 风平浪静、无事发生
  • 论文解读:《DeepGray:基于灰度图像和深度学习的恶意软件分类方法》
  • OneCode 智能化UI布局与定位:注解驱动的视觉编排艺术
  • 图灵完备之路(数电学习三分钟)----数据选择器与总线
  • 使用alist+RaiDrive+webdav将百度夸克网盘变为本地电脑磁盘方法教程
  • 《人生顶层设计》读书笔记7
  • J20250704 算法题5道
  • css-多条记录,自动换行与自动并行布局及gap兼容
  • 智能私域运营中枢:从客户视角看 SCRM 的体验革新与价值重构
  • $route
  • Dash 安装使用教程
  • 浅层神经网络:原理与Python实现
  • Golang服务端处理Unity 3D游戏地图与碰撞的详细实现
  • docker运行的一些常用命令
  • SAP入门到放弃系列-流程订单-Process Instruction Category-自定义设置
  • QNetworkAccessManager异步请求有时候操作UI控件崩溃问题
  • ASP.NET MVC架构 路由提取