修改德哥的PostgreSQL求解数独SQL在cedardb上运行

cedardb与PostgreSQL语法兼容,但是直接运行结果是NULL,求解失败。将中间子查询的结果打印出来看出了原因。

同样的输入数据,输出的位掩码不同,比如初始化列和宫编码,数组中的元素值相同,顺序不同。

cedardb 输出

复制代码
id board cols boxes 
1 000000010400000000020000000000050407008000300001090000300400200050100000000806000  {12,64,32,18,1,14,137,272,129} {20,1,2,10,0,129,169,272,76}

PostgreSQL输出

复制代码
  1 | 000000010400000000020000000000050407008000300001090000300400200050100000000806000 | {12,18,129,137,272,32,14,1,64} | {10,0,1,129,272,76,20,169,2} 

将相应的聚合函数 array_agg(m)改为明确的排序 array_agg(m ORDER BY c), 在cedardb 输出了与PostgreSQL相同的结果。

复制代码
id board cols boxes 
1 000000010400000000020000000000050407008000300001090000300400200050100000000806000  {12,18,129,137,272,32,14,1,64} {10,0,1,129,272,76,20,169,2}

再运行完整SQL,cedardb 求解出了示例数据的结果,时间约是PostgreSQL的十分之一。

PostgreSQL输出

复制代码
 id |  puzzle   |  result
----+-----------+-----------
  3 | 8????????+| 812753649+
    | ??36?????+| 943682175+
    | ?7??9?2??+| 675491283+
    | ?5???7???+| 154237896+
    | ????457??+| 369845721+
    | ???1???3?+| 287169534+
    | ??1????68+| 521974368+
    | ??85???1?+| 438526917+
    | ?9????4?? | 796318452
(1 row)

Time: 1211.606 ms (00:01.212)

cedardb 输出

复制代码
id puzzle result
3 8????????
??36?????
?7??9?2??
?5???7???
????457??
???1???3?
??1????68
??85???1?
?9????4?? 812753649
943682175
675491283
154237896
369845721
287169534
521974368
438526917
796318452

2026-01-24 05:37:18.850220019 UTC       INFO:     [s] execution: (0.116115 min, 0.116115 max, 0.116115 median, 0.0% relMAD, 0.116115 avg, 0.000000 sdev, 4 scale, nan IPC, nan CPUs, nan GHz) compilation: (0.006032 min, 0.006032 max, 0.006032 median, 0.0% relMAD, 0.006032 avg, 0.000000 sdev)

但是如果是多个行,cedardb就报错了,看来是在生成执行计划阶段报错,原因还需要进一步研究。

复制代码
2026-01-24 11:54:10.854135438 UTC       FATAL:   Assertion `(x != y) && (lca(x, y) == x)` failed. /cedardb/plan/algebra/operators/Operator.cpp:280: static cedar::algebra::Operator* cedar::algebra::Operator::LinkCutNode::findContainingChild(cedar::algebra::Operator*, cedar::algebra::Operator*)
CedarDB v2026-01-22 current-amd64
cedardb 0x31aff8b
相关推荐
蜡笔小炘8 分钟前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长12 分钟前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
Re.不晚1 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
老邓计算机毕设1 小时前
SSM智慧社区信息化服务平台4v5hv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·智慧社区、·信息化平台
麦聪聊数据1 小时前
为何通用堡垒机无法在数据库运维中实现精准风控?
数据库·sql·安全·低代码·架构
2301_790300961 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
m0_736919102 小时前
用Pandas处理时间序列数据(Time Series)
jvm·数据库·python
亓才孓2 小时前
[JDBC]PreparedStatement替代Statement
java·数据库
m0_466525292 小时前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊3 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python