Mercurial > pub > bltoolkit
view Source/DataAccess/SqlQuery.cs @ 1:8f65451dc28f
Исправлена проблема с фабрикой и выборкой нескольких объектов в linq выражении
author | cin |
---|---|
date | Fri, 28 Mar 2014 01:04:56 +0400 |
parents | f990fcb411a9 |
children |
line wrap: on
line source
using System; using System.Collections; using BLToolkit.Data; using BLToolkit.Reflection.Extension; namespace BLToolkit.DataAccess { public class SqlQuery : SqlQueryBase { #region Constructors public SqlQuery() { } public SqlQuery(DbManager dbManager) : base(dbManager) { } public SqlQuery(DbManager dbManager, bool dispose) : base(dbManager, dispose) { } public SqlQuery(ExtensionList extensions) { Extensions = extensions; } #endregion #region Overrides public SqlQueryInfo GetSqlQueryInfo<T>(DbManager db, string actionName) { return base.GetSqlQueryInfo(db, typeof(T), actionName); } #endregion #region SelectByKey public virtual object SelectByKey(DbManager db, Type type, params object[] keys) { var query = GetSqlQueryInfo(db, type, "SelectByKey"); return db .SetCommand(query.QueryText, query.GetParameters(db, keys)) .ExecuteObject(type); } public virtual object SelectByKey(Type type, params object[] keys) { var db = GetDbManager(); try { return SelectByKey(db, type, keys); } finally { if (DisposeDbManager) db.Dispose(); } } public virtual T SelectByKey<T>(DbManager db, params object[] keys) { var query = GetSqlQueryInfo(db, typeof(T), "SelectByKey"); return db .SetCommand(query.QueryText, query.GetParameters(db, keys)) .ExecuteObject<T>(); } public virtual T SelectByKey<T>(params object[] keys) { var db = GetDbManager(); try { return SelectByKey<T>(db, keys); } finally { if (DisposeDbManager) db.Dispose(); } } #endregion #region SelectAll public virtual ArrayList SelectAll(DbManager db, Type type) { var query = GetSqlQueryInfo(db, type, "SelectAll"); return db .SetCommand(query.QueryText) .ExecuteList(type); } public virtual IList SelectAll(DbManager db, IList list, Type type) { var query = GetSqlQueryInfo(db, type, "SelectAll"); return db .SetCommand(query.QueryText) .ExecuteList(list, type); } public virtual ArrayList SelectAll(Type type) { var db = GetDbManager(); try { return SelectAll(db, type); } finally { Dispose(db); } } public virtual IList SelectAll(IList list, Type type) { var db = GetDbManager(); try { return SelectAll(db, list, type); } finally { Dispose(db); } } public virtual System.Collections.Generic.List<T> SelectAll<T>(DbManager db) { var query = GetSqlQueryInfo(db, typeof(T), "SelectAll"); return db .SetCommand(query.QueryText) .ExecuteList<T>(); } public virtual TL SelectAll<TL,T>(DbManager db, TL list) where TL : System.Collections.Generic.IList<T> { var query = GetSqlQueryInfo(db, typeof(T), "SelectAll"); return db .SetCommand(query.QueryText) .ExecuteList<TL,T>(list); } public virtual TL SelectAll<TL,T>(DbManager db) where TL : System.Collections.Generic.IList<T>, new() { return SelectAll<TL,T>(db, new TL()); } public virtual System.Collections.Generic.List<T> SelectAll<T>() { var db = GetDbManager(); try { return SelectAll<T>(db); } finally { Dispose(db); } } public virtual TL SelectAll<TL,T>(TL list) where TL : System.Collections.Generic.IList<T> { var db = GetDbManager(); try { return SelectAll<TL,T>(db, list); } finally { Dispose(db); } } public virtual TL SelectAll<TL,T>() where TL : System.Collections.Generic.IList<T>, new() { return SelectAll<TL,T>(new TL()); } #endregion #region Insert public virtual int Insert(DbManager db, object obj) { var query = GetSqlQueryInfo(db, obj.GetType(), "Insert"); return db .SetCommand(query.QueryText, query.GetParameters(db, obj)) .ExecuteNonQuery(); } public virtual int Insert(object obj) { var db = GetDbManager(); try { return Insert(db, obj); } finally { Dispose(db); } } #endregion #region Update public virtual int Update(DbManager db, object obj) { var query = GetSqlQueryInfo(db, obj.GetType(), "Update"); return db .SetCommand(query.QueryText, query.GetParameters(db, obj)) .ExecuteNonQuery(); } public virtual int Update(object obj) { var db = GetDbManager(); try { return Update(db, obj); } finally { Dispose(db); } } #endregion #region DeleteByKey public virtual int DeleteByKey(DbManager db, Type type, params object[] key) { var query = GetSqlQueryInfo(db, type, "Delete"); return db .SetCommand(query.QueryText, query.GetParameters(db, key)) .ExecuteNonQuery(); } public virtual int DeleteByKey(Type type, params object[] key) { var db = GetDbManager(); try { return DeleteByKey(db, type, key); } finally { Dispose(db); } } public virtual int DeleteByKey<T>(DbManager db, params object[] key) { var query = GetSqlQueryInfo(db, typeof(T), "Delete"); return db .SetCommand(query.QueryText, query.GetParameters(db, key)) .ExecuteNonQuery(); } public virtual int DeleteByKey<T>(params object[] key) { var db = GetDbManager(); try { return DeleteByKey<T>(db, key); } finally { Dispose(db); } } #endregion #region Delete public virtual int Delete(DbManager db, object obj) { var query = GetSqlQueryInfo(db, obj.GetType(), "Delete"); return db .SetCommand(query.QueryText, query.GetParameters(db, obj)) .ExecuteNonQuery(); } public virtual int Delete(object obj) { var db = GetDbManager(); try { return Delete(db, obj); } finally { Dispose(db); } } #endregion } }