50 lines
1.5 KiB
C#
50 lines
1.5 KiB
C#
using System;
|
|
using System.Text.RegularExpressions;
|
|
using System.Linq;
|
|
using System.Data;
|
|
|
|
namespace SqlSugar
|
|
{
|
|
public interface IDataAdapter
|
|
{
|
|
void Fill(DataSet ds);
|
|
}
|
|
public partial class SqliteProvider : AdoProvider
|
|
{
|
|
public override void ExecuteBefore(string sql, SugarParameter[] parameters)
|
|
{
|
|
this.BeforeTime = DateTime.Now;
|
|
if (sql.HasValue() && parameters.HasValue())
|
|
{
|
|
foreach (var parameter in parameters)
|
|
{
|
|
//Compatible with.NET CORE parameters case
|
|
var name = parameter.ParameterName;
|
|
if (!sql.Contains(name) && Regex.IsMatch(sql, "(" + name + "$)" + "|(" + name + @"[ ,\,])", RegexOptions.IgnoreCase))
|
|
{
|
|
parameter.ParameterName = Regex.Match(sql, "(" + name + "$)" + "|(" + name + @"[ ,\,])", RegexOptions.IgnoreCase).Value.Trim();
|
|
}
|
|
}
|
|
}
|
|
if (this.IsEnableLogEvent)
|
|
{
|
|
Action<string, SugarParameter[]> action = LogEventStarting;
|
|
if (action != null)
|
|
{
|
|
if (parameters == null || parameters.Length == 0)
|
|
{
|
|
action(sql, new SugarParameter[] { });
|
|
}
|
|
else
|
|
{
|
|
action(sql, parameters);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
namespace System.Data.Sqlite
|
|
{
|
|
|
|
} |