diff --git a/src/Interface/IQueryGenerator.cs b/src/Interface/IQueryGenerator.cs new file mode 100644 index 0000000..8277763 --- /dev/null +++ b/src/Interface/IQueryGenerator.cs @@ -0,0 +1,85 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace DbSyncKit.Templates.Interface +{ + /// + /// Defines methods for generating SQL queries and handling query-related operations. + /// + public interface IQueryGenerator : IDisposable + { + /// + /// Generates a SELECT query for retrieving data from a database table. + /// + /// The name of the database table. + /// The list of columns to be selected. + /// The schema name of the database table. + /// A string representing the generated SELECT query. + string GenerateSelectQuery(string tableName, List ListOfColumns, string schemaName); + + /// + /// Generates an UPDATE query for updating data in a database table. + /// + /// The entity with the updated data. + /// The list of key columns used for updating. + /// The list of columns to be excluded from the update. + /// A dictionary representing the properties and their new values to be updated. + /// A string representing the generated UPDATE query. + string GenerateUpdateQuery(T DataContract, List keyColumns, List excludedColumns, (string propName, object propValue)[] editedProperties); + + /// + /// Generates a DELETE query for deleting data from a database table. + /// + /// The entity representing the data to be deleted. + /// The list of key columns used for deletion. + /// A string representing the generated DELETE query. + string GenerateDeleteQuery(T entity, List keyColumns); + + /// + /// Generates an INSERT query for inserting data into a database table. + /// + /// The entity representing the data to be inserted. + /// The list of key columns used for insertion. + /// The list of columns to be excluded from the insertion. + /// A string representing the generated INSERT query. + string GenerateInsertQuery(T entity, List keyColumns, List excludedColumns); + + /// + /// Generates a SQL comment. + /// + /// The comment text. + /// A string representing the generated comment. + string GenerateComment(string comment); + + /// + /// Gets a condition for use in a SQL WHERE clause based on the entity and key columns. + /// + /// The entity for which the condition is generated. + /// The list of key columns used to create the condition. + /// A string representing the generated condition for a SQL WHERE clause. + List GetCondition(T entity, List keyColumns); + + /// + /// Escapes special characters in the input to make it SQL-safe. + /// + /// The input object or string to be escaped. + /// The escaped object or string. + object? EscapeValue(object? input); + + /// + /// Escapes the input column name to be used safely in SQL queries. + /// + /// The input column name to be escaped. + /// The escaped column name. + string EscapeColumn(string? input); + + /// + /// Generates a SQL batch separator ('GO' statement in SQL Server) used to execute batches of SQL statements. + /// + /// A string representing the generated batch separator. + string GenerateBatchSeparator(); + } +} diff --git a/src/QueryGenerationManager.cs b/src/QueryGenerationManager.cs new file mode 100644 index 0000000..620f35c --- /dev/null +++ b/src/QueryGenerationManager.cs @@ -0,0 +1,94 @@ +using DbSyncKit.Templates.Interface; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace DbSyncKit.Templates +{ + /// + /// Manages the generation of SQL queries for data operations by delegating the query generation tasks + /// to an implementation of the interface. + /// + /// + /// This class acts as a wrapper around an instance of and forwards + /// query generation requests to the underlying implementation. + /// + public class QueryGenerationManager : IQueryGenerator + { + private readonly IQueryGenerator _querryGenerator; + + /// + /// The underlying query generator instance used for actual query generation. + /// + public QueryGenerationManager(IQueryGenerator querryGenerator) + { + _querryGenerator = querryGenerator; + } + + #region Public Methods + /// + public string GenerateSelectQuery(string tableName, List listOfColumns, string schemaName) + { + return _querryGenerator.GenerateSelectQuery(tableName, listOfColumns, schemaName); + } + + /// + public string GenerateUpdateQuery(T DataContract, List keyColumns, List excludedColumns, (string propName, object propValue)[] editedProperties) + { + return _querryGenerator.GenerateUpdateQuery(DataContract, keyColumns, excludedColumns, editedProperties); + } + + /// + public string GenerateDeleteQuery(T entity, List keyColumns) + { + return _querryGenerator.GenerateDeleteQuery(entity, keyColumns); + } + + /// + public string GenerateInsertQuery(T entity, List keyColumns, List excludedColumns) + { + return _querryGenerator.GenerateInsertQuery(entity, keyColumns, excludedColumns); + } + + /// + public string GenerateComment(string comment) + { + return _querryGenerator.GenerateComment(comment); + } + + /// + public List GetCondition(T entity, List keyColumns) + { + return _querryGenerator.GetCondition(entity, keyColumns); + } + + /// + public object? EscapeValue(object? input) + { + return _querryGenerator.EscapeValue(input); + } + + /// + public string EscapeColumn(string? input) + { + return _querryGenerator.EscapeColumn(input); + } + + /// + public string GenerateBatchSeparator() + { + return _querryGenerator.GenerateBatchSeparator(); + } + + /// + public void Dispose() + { + _querryGenerator.Dispose(); + } + + #endregion + } + +}