一个用SQL Sever求解数独的SQL

分别从 文章1 https://axial-sql.com/info/exploring-sql-server-solving-sudoku-with-t-sql/ 和文章2 https://www.sqlservercentral.com/blogs/tsql-sudoku-ii-2 看到的代码和解释,思路还是穷举法。然后经过删减,终于能执行出来了,注释掉了不懂要怎么修改的部分,需要进一步研究。

sql 复制代码
WITH x( s, ind ) AS
( 
  SELECT CONVERT(VARCHAR(100),'53  7    6  195    98    6 8   6   34  8 3  17   2   6 6    28    419  5    8  79'), 
  CHARINDEX(' ', '53  7    6  195    98    6 8   6   34  8 3  17   2   6 6    28    419  5    8  79') AS ind
  UNION ALL
  SELECT CONVERT(VARCHAR(100), SUBSTRING(s, 1, ind - 1) + CONVERT(CHAR(1), z) + SUBSTRING(s, ind + 1, 81)),
         CHARINDEX(' ', s, ind + 1) AS ind
  FROM x
    CROSS APPLY ( VALUES(1),(2),(3),(4),(5),(6),(7),(8),(9)) z (z)
  WHERE ind > 0
  AND NOT EXISTS (
    SELECT NULL
    FROM ( VALUES(1),(2),(3),(4),(5),(6),(7),(8),(9)) ww (lp)
    WHERE z = SUBSTRING(s, (ind - 1) % 9 - 8 + lp * 9, 1)
    OR    z = SUBSTRING(s, ((ind - 1) / 9) * 9 + lp, 1)
    OR    z = SUBSTRING(s, (((ind - 1) / 3) % 3) * 3 + (((ind - 1) / 27) * 27) + lp + (((lp - 1) / 3) * 6), 1)
  )
), Sud AS (
  SELECT TOP 9 SUBSTRING(s, ROW_NUMBER() OVER (ORDER BY s) * 9 - 8, ROW_NUMBER() OVER (ORDER BY s) * 9 - (ROW_NUMBER() OVER (ORDER BY s) * 9 - 9)) AS ConcatRow
  FROM x
  CROSS APPLY ( VALUES(1),(2),(3),(4),(5),(6),(7),(8),(9)) y(N)
  WHERE ind = 0
)
, SudTable (RowCol,ConcatRow) as(
Select Row_Number() Over (Order by (Select 1)),CONVERT(VARCHAR(10), ConcatRow)
From Sud
)
select * from SudTable;
/*
SELECT c1.RowCol , [1], [2], [3], [4], [5], [6], [7], [8], [9]
FROM (
  SELECT S.RowCol,  ROW_NUMBER() OVER (PARTITION BY RowCol ORDER BY ConcatRow) as ColNo , SUBSTRING(ConcatRow, ROW_NUMBER() OVER (PARTITION BY S.RowCol ORDER BY ConcatRow), 1) as Data
  FROM SudTable S
  CROSS APPLY ( VALUES(1),(2),(3),(4),(5),(6),(7),(8),(9)) x(N)
) Intr
PIVOT (
  MAX(Data)
  FOR ColNo IN ([1], [2], [3], [4], [5], [6], [7], [8], [9])
)  AS C1
WHERE c1.RowCol = S.RowCol
ORDER BY S.RowCol ASC
*/
;
go

输出结果

复制代码
mssql@52f277ddc992:/$ /opt/mssql-tools18/bin/sqlcmd -S localhost -U sa -No -i /par/tsqlsudoku.txt -P Pass_123
RowCol               ConcatRow
-------------------- ----------
                   1 534678912
                   2 672195348
                   3 198342567
                   4 859761423
                   5 426853791
                   6 713924856
                   7 961537284
                   8 287419635
                   9 345286179

(9 rows affected)
相关推荐
陌上丨8 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56788 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw8 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30739 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道9 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据10 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务10 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯11 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七12 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草12 小时前
redis-9-哨兵
数据库·redis·bootstrap