我正在尝试编写一个正则表达式,它将一些样板 SQL 代码重新格式化为一个更干净的版本。这是一个例子。
我有:
SELECT
[Person].[Name]
[Person].[Address],
[Sales].[TotalAmount]
我想:
SELECT
[Name] = [Person].[Name],
[Address] = [Person].[Address],
[TotalAmount] = [Sales].[TotalAmount]
我可以写一个表达式将字段名称移动到赋值语句的左侧,没问题。棘手的部分是正确的间距——有没有办法在替换中使用匹配的长度?另外,要使用最长匹配的长度吗?这样 "[Name]" 后跟 length("TotalAmount") - length("Name") = 7 个空格,"[Address]" 后跟 length("TotalAmount") - length("Address") = 4 个空格,等等?
我不确定这对正则表达式是否可行,但我想我会把它扔在那里,希望有一些正则表达式大师知道如何做到这一点。