83 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C#
		
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C#
		
	
	
| using Microsoft.EntityFrameworkCore;
 | |
| using Microsoft.EntityFrameworkCore.Infrastructure;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Data;
 | |
| using System.Data.Common;
 | |
| using Microsoft.Data.SqlClient;
 | |
| using System.Linq;
 | |
| using System.Reflection;
 | |
| using System.Text;
 | |
| using System.Threading.Tasks;
 | |
| 
 | |
| namespace IRaCIS.Core.Infra.EFCore
 | |
| {
 | |
|     public static class EFSqlQuery
 | |
|     {
 | |
|         public static IEnumerable<T> SqlQuery<T>(this DatabaseFacade facade, string sql, params object[] parameters) where T : class, new()
 | |
|         {
 | |
|             DataTable dt = SqlQuery(facade, sql, parameters);
 | |
|             return dt.ToEnumerable<T>();
 | |
|         }
 | |
| 
 | |
|         public static IEnumerable<T> ToEnumerable<T>(this DataTable dt) where T : class, new()
 | |
|         {
 | |
|             PropertyInfo[] propertyInfos = typeof(T).GetProperties();
 | |
|             T[] ts = new T[dt.Rows.Count];
 | |
|             int i = 0;
 | |
|             foreach (DataRow row in dt.Rows)
 | |
|             {
 | |
|                 T t = new T();
 | |
|                 foreach (PropertyInfo p in propertyInfos)
 | |
|                 {
 | |
|                     if (dt.Columns.IndexOf(p.Name) != -1 && row[p.Name] != DBNull.Value)
 | |
|                         p.SetValue(t, row[p.Name], null);
 | |
|                 }
 | |
|                 ts[i] = t;
 | |
|                 i++;
 | |
|             }
 | |
|             return ts;
 | |
|         }
 | |
| 
 | |
|         public static DataTable SqlQuery(this DatabaseFacade facade, string sql, params object[] parameters)
 | |
|         {
 | |
|             DbCommand cmd = CreateCommand(facade, sql, out DbConnection conn, parameters);
 | |
|             DbDataReader reader = cmd.ExecuteReader();
 | |
|             DataTable dt = new DataTable();
 | |
|             dt.Load(reader);
 | |
|             reader.Close();
 | |
|             conn.Close();
 | |
|             return dt;
 | |
|         }
 | |
| 
 | |
|         private static DbCommand CreateCommand(DatabaseFacade facade, string sql, out DbConnection dbConn, params object[] parameters)
 | |
|         {
 | |
|             DbConnection conn = facade.GetDbConnection();
 | |
|             dbConn = conn;
 | |
|             conn.Open();
 | |
|             DbCommand cmd = conn.CreateCommand();
 | |
|             if (facade.IsSqlServer())
 | |
|             {
 | |
|                 cmd.CommandText = sql;
 | |
|                 CombineParams(ref cmd, parameters);
 | |
|             }
 | |
|             return cmd;
 | |
|         }
 | |
| 
 | |
|         private static void CombineParams(ref DbCommand command, params object[] parameters)
 | |
|         {
 | |
|             if (parameters != null)
 | |
|             {
 | |
|                 foreach (SqlParameter parameter in parameters)
 | |
|                 {
 | |
|                     if (!parameter.ParameterName.Contains("@"))
 | |
|                         parameter.ParameterName = $"@{parameter.ParameterName}";
 | |
|                     command.Parameters.Add(parameter);
 | |
|                 }
 | |
| 
 | |
|               
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |