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

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,47 @@
using Microsoft.SqlServer.TransactSql.ScriptDom;
using SQLLinter.Common;
using SQLLinter.Common.Helpers;
namespace SQLLinter.Infrastructure.Rules;
public class NamedConstraintRule : BaseRuleVisitor, IRule
{
public override string Text => "Именованные ограничения во временных таблицах могут вызывать коллизии при параллельном запуске: {0}";
public override void Visit(CreateTableStatement node)
{
// применять правило только к временным таблицам
if (!node.SchemaObjectName.BaseIdentifier.Value.Contains("#"))
{
return;
}
var constraintVisitor = new ConstraintVisitor();
node.AcceptChildren(constraintVisitor);
if (constraintVisitor.NamedConstraintExists)
{
AddViolation(node, SQLHelpers.ObjectGetFullName(node.SchemaObjectName));
}
}
private class ConstraintVisitor : TSqlFragmentVisitor
{
public bool NamedConstraintExists
{
get;
private set;
}
public override void Visit(ConstraintDefinition node)
{
if (NamedConstraintExists)
{
return;
}
NamedConstraintExists = node.ConstraintIdentifier != null;
}
}
}