From c9d9e6d23ad7b6fdf25f30de9b4a84be23885e16 Mon Sep 17 00:00:00 2001 From: vman Date: Wed, 30 Nov 2022 14:59:09 -0500 Subject: Project cleanup + analyzer updates --- VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs | 58 ++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs (limited to 'VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs') diff --git a/VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs b/VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs new file mode 100644 index 0000000..d33854a --- /dev/null +++ b/VNLib.Plugins.Extensions.Data/SQL/SqlVariable.cs @@ -0,0 +1,58 @@ +/* +* Copyright (c) 2022 Vaughn Nugent +* +* Library: VNLib +* Package: VNLib.Plugins.Extensions.Data +* File: SqlVariable.cs +* +* SqlVariable.cs is part of VNLib.Plugins.Extensions.Data which is part of the larger +* VNLib collection of libraries and utilities. +* +* VNLib.Plugins.Extensions.Data is free software: you can redistribute it and/or modify +* it under the terms of the GNU General Public License as published +* by the Free Software Foundation, either version 2 of the License, +* or (at your option) any later version. +* +* VNLib.Plugins.Extensions.Data is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +* General Public License for more details. +* +* You should have received a copy of the GNU General Public License +* along with VNLib.Plugins.Extensions.Data. If not, see http://www.gnu.org/licenses/. +*/ + +using System; +using System.Data; + +namespace VNLib.Plugins.Extensions.Data.SQL +{ + /// + /// Property attribute that specifies the property is to be used for a given command variable + /// + [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field)] + public class SqlVariable : Attribute + { + public string VariableName { get; init; } + public DbType DataType { get; init; } + public ParameterDirection Direction { get; init; } + public int Size { get; init; } + public bool Nullable { get; init; } + /// + /// Specifies the property to be used as an SQL variable + /// + /// Sql statement variable this property will substitute + /// The sql data the property will represent + /// Data direction during execution + /// Column size + /// Is this property allowed to be null + public SqlVariable(string variableName, DbType dataType, ParameterDirection direction, int size, bool isNullable) + { + this.VariableName = variableName; + this.DataType = dataType; + this.Direction = direction; + this.Size = size; + this.Nullable = isNullable; + } + } +} -- cgit