mirror of
https://github.com/nsnail/FreeSql.git
synced 2025-06-19 04:18:16 +08:00
- 调整 Aop 改为 event 事件;
- 调整 Ado.AopCommandExecuting/AopCommandExecuted 到 Aop.CommandBefore/After; - 增加 Aop.TraceBefore/After 事件;
This commit is contained in:
@ -160,7 +160,9 @@ namespace FreeSql
|
||||
await DbContextExecCommandAsync();
|
||||
//删除没有保存的数据
|
||||
var propValEach = GetItemValue(item, prop) as IEnumerable;
|
||||
await _db.Orm.Delete<object>().AsType(tref.RefEntityType).WhereDynamic(propValEach, true).ExecuteAffrowsAsync();
|
||||
await _db.Orm.Delete<object>().AsType(tref.RefEntityType)
|
||||
.WithTransaction(_uow?.GetOrBeginTransaction())
|
||||
.WhereDynamic(propValEach, true).ExecuteAffrowsAsync();
|
||||
}
|
||||
}
|
||||
finally
|
||||
@ -213,7 +215,8 @@ namespace FreeSql
|
||||
|
||||
if (curList.Any() == false) //全部删除
|
||||
{
|
||||
var delall = _db.Orm.Delete<object>().AsType(tref.RefMiddleEntityType);
|
||||
var delall = _db.Orm.Delete<object>().AsType(tref.RefMiddleEntityType)
|
||||
.WithTransaction(_uow?.GetOrBeginTransaction());
|
||||
foreach (var midWhere in midWheres) delall.Where(midWhere);
|
||||
var sql = delall.ToSql();
|
||||
await delall.ExecuteAffrowsAsync();
|
||||
|
@ -172,7 +172,9 @@ namespace FreeSql
|
||||
DbContextExecCommand();
|
||||
//删除没有保存的数据
|
||||
var propValEach = GetItemValue(item, prop) as IEnumerable;
|
||||
_db.Orm.Delete<object>().AsType(tref.RefEntityType).WhereDynamic(propValEach, true).ExecuteAffrows();
|
||||
_db.Orm.Delete<object>().AsType(tref.RefEntityType)
|
||||
.WithTransaction(_uow?.GetOrBeginTransaction())
|
||||
.WhereDynamic(propValEach, true).ExecuteAffrows();
|
||||
}
|
||||
}
|
||||
finally
|
||||
@ -225,7 +227,8 @@ namespace FreeSql
|
||||
|
||||
if (curList.Any() == false) //全部删除
|
||||
{
|
||||
var delall = _db.Orm.Delete<object>().AsType(tref.RefMiddleEntityType);
|
||||
var delall = _db.Orm.Delete<object>().AsType(tref.RefMiddleEntityType)
|
||||
.WithTransaction(_uow?.GetOrBeginTransaction());
|
||||
foreach (var midWhere in midWheres) delall.Where(midWhere);
|
||||
var sql = delall.ToSql();
|
||||
delall.ExecuteAffrows();
|
||||
|
@ -110,13 +110,6 @@
|
||||
清空状态数据
|
||||
</summary>
|
||||
</member>
|
||||
<member name="M:FreeSql.DbSet`1.RemoveAsync(System.Linq.Expressions.Expression{System.Func{`0,System.Boolean}})">
|
||||
<summary>
|
||||
根据 lambda 条件删除数据
|
||||
</summary>
|
||||
<param name="predicate"></param>
|
||||
<returns></returns>
|
||||
</member>
|
||||
<member name="M:FreeSql.DbSet`1.Add(`0)">
|
||||
<summary>
|
||||
添加
|
||||
@ -251,6 +244,13 @@
|
||||
<param name="entity">实体对象</param>
|
||||
<param name="propertyName">属性名</param>
|
||||
</member>
|
||||
<member name="M:FreeSql.IUnitOfWork.GetOrBeginTransaction(System.Boolean)">
|
||||
<summary>
|
||||
开启事务,或者返回已开启的事务
|
||||
</summary>
|
||||
<param name="isCreate">若未开启事务,则开启</param>
|
||||
<returns></returns>
|
||||
</member>
|
||||
<member name="P:FreeSql.IUnitOfWork.Enable">
|
||||
<summary>
|
||||
是否启用工作单元
|
||||
|
@ -8,6 +8,11 @@ namespace FreeSql
|
||||
public interface IUnitOfWork : IDisposable
|
||||
{
|
||||
|
||||
/// <summary>
|
||||
/// 开启事务,或者返回已开启的事务
|
||||
/// </summary>
|
||||
/// <param name="isCreate">若未开启事务,则开启</param>
|
||||
/// <returns></returns>
|
||||
DbTransaction GetOrBeginTransaction(bool isCreate = true);
|
||||
|
||||
IsolationLevel? IsolationLevel { get; set; }
|
||||
|
@ -24,6 +24,8 @@ namespace FreeSql
|
||||
protected IFreeSql _fsql;
|
||||
protected Object<DbConnection> _conn;
|
||||
protected DbTransaction _tran;
|
||||
protected Aop.TraceBeforeEventArgs _tranBefore;
|
||||
protected Aop.TraceBeforeEventArgs _uowBefore;
|
||||
|
||||
/// <summary>
|
||||
/// 开启事务后有值,是 UnitOfWork 的唯一标识<para></para>
|
||||
@ -35,6 +37,11 @@ namespace FreeSql
|
||||
public UnitOfWork(IFreeSql fsql)
|
||||
{
|
||||
_fsql = fsql;
|
||||
if (_fsql == null) throw new ArgumentNullException(nameof(fsql));
|
||||
|
||||
_uowBefore = new Aop.TraceBeforeEventArgs("UnitOfWork", null);
|
||||
_fsql?.Aop.TraceBeforeHandler?.Invoke(this, _uowBefore);
|
||||
|
||||
#if netcoreapp
|
||||
Current.Value = this;
|
||||
#endif
|
||||
@ -77,49 +84,83 @@ namespace FreeSql
|
||||
if (!Enable) return null;
|
||||
if (_conn != null) _fsql.Ado.MasterPool.Return(_conn);
|
||||
|
||||
_conn = _fsql.Ado.MasterPool.Get();
|
||||
_tranBefore = new Aop.TraceBeforeEventArgs("BeginTransaction", IsolationLevel);
|
||||
_fsql?.Aop.TraceBeforeHandler?.Invoke(this, _tranBefore);
|
||||
try
|
||||
{
|
||||
_tran = IsolationLevel == null ?
|
||||
_conn.Value.BeginTransaction() :
|
||||
_conn.Value.BeginTransaction(IsolationLevel.Value);
|
||||
_conn = _fsql.Ado.MasterPool.Get();
|
||||
try
|
||||
{
|
||||
_tran = IsolationLevel == null ?
|
||||
_conn.Value.BeginTransaction() :
|
||||
_conn.Value.BeginTransaction(IsolationLevel.Value);
|
||||
|
||||
this.Id = $"{DateTime.Now.ToString("yyyyMMdd_HHmmss")}_{Interlocked.Increment(ref _seed)}";
|
||||
DebugBeingUsed.TryAdd(this.Id, this);
|
||||
this.Id = $"{DateTime.Now.ToString("yyyyMMdd_HHmmss")}_{Interlocked.Increment(ref _seed)}";
|
||||
DebugBeingUsed.TryAdd(this.Id, this);
|
||||
}
|
||||
catch
|
||||
{
|
||||
ReturnObject();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
catch
|
||||
catch (Exception ex)
|
||||
{
|
||||
ReturnObject();
|
||||
throw;
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_tranBefore, "失败", ex));
|
||||
throw ex;
|
||||
}
|
||||
return _tran;
|
||||
}
|
||||
|
||||
public void Commit()
|
||||
{
|
||||
var isCommited = false;
|
||||
try
|
||||
{
|
||||
if (_tran != null)
|
||||
{
|
||||
_tran.Commit();
|
||||
isCommited = true;
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_tranBefore, "提交", null));
|
||||
|
||||
if (EntityChangeReport != null && EntityChangeReport.OnChange != null && EntityChangeReport.Report.Any() == true)
|
||||
EntityChangeReport.OnChange.Invoke(EntityChangeReport.Report);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
if (isCommited == false)
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_tranBefore, "提交失败", ex));
|
||||
throw ex;
|
||||
}
|
||||
finally
|
||||
{
|
||||
ReturnObject();
|
||||
_tranBefore = null;
|
||||
}
|
||||
}
|
||||
public void Rollback()
|
||||
{
|
||||
var isRollbacked = false;
|
||||
try
|
||||
{
|
||||
if (_tran != null) _tran.Rollback();
|
||||
if (_tran != null)
|
||||
{
|
||||
_tran.Rollback();
|
||||
isRollbacked = true;
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_tranBefore, "回滚", null));
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
if (isRollbacked == false)
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_tranBefore, "回滚失败", ex));
|
||||
throw ex;
|
||||
}
|
||||
finally
|
||||
{
|
||||
ReturnObject();
|
||||
_tranBefore = null;
|
||||
}
|
||||
}
|
||||
|
||||
@ -137,6 +178,7 @@ namespace FreeSql
|
||||
}
|
||||
finally
|
||||
{
|
||||
_fsql?.Aop.TraceAfterHandler?.Invoke(this, new Aop.TraceAfterEventArgs(_uowBefore, "释放", null));
|
||||
GC.SuppressFinalize(this);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user