Добавьте файлы проекта.

This commit is contained in:
2025-12-07 08:52:05 +03:00
parent 95344cd7a7
commit 226b6b6b21
118 changed files with 5249 additions and 0 deletions

View File

@@ -0,0 +1,30 @@
using Microsoft.SqlServer.TransactSql.ScriptDom;
using SQLLinter.Common;
using System.Linq;
namespace SQLLinter.Infrastructure.Rules;
public class OrderByWithoutTopOffsetRule : BaseRuleVisitor
{
public override string Text => "Обнаружен ORDER BY без TOP или OFFSET: {0}";
public override void Visit(QuerySpecification node)
{
if (node.OrderByClause != null && node.TopRowFilter == null && node.OffsetClause == null)
{
var tokens = node.OrderByClause.ScriptTokenStream
.Skip(node.OrderByClause.FirstTokenIndex)
.Take(node.OrderByClause.LastTokenIndex - node.OrderByClause.FirstTokenIndex + 1)
.Select(t => t.TokenType == TSqlTokenType.WhiteSpace ? " " : t.Text);
var orderByString = string.Join("", tokens);
if (orderByString.Length > 53)
{
orderByString = orderByString[..50] + "...";
}
AddViolation(node.OrderByClause, orderByString);
}
base.Visit(node);
}
}