繼上一篇,以及上上篇,咱們對SqlSugar有了一個大概的認識,可是這並不完美,由於那些都是理論知識,沒法描述咱們工程開發中實際狀況。而這一篇,將帶領小夥伴們一塊兒試着寫一個能在工程中使用的模板類。程序員
SqlSugar在操做的時候須要一個Client,用來管理數據庫鏈接,並操做數據庫。因此咱們寫一個DbContext用來建立Client:sql
public class DefaultContext
{
public SqlSugarClient Client { get; }
public DefaultContext(string connectionString, DbType dbType)
{
Client = new SqlSugarClient(new ConnectionConfig
{
ConnectionString = connectionString,//"Data Source=./demo.db",
DbType = dbType,
IsAutoCloseConnection = true,
InitKeyType = InitKeyType.Attribute
});
Client.CodeFirst.InitTables(typeof(Dept), typeof(Person), typeof(Employee));
Client.Aop.OnLogExecuting = (sql, paramters) =>
{
Console.WriteLine(sql);
};
}
public SimpleClient<T> CreateClient<T>() where T : class, new()
{
return Client.GetSimpleClient<T>();
}
}
SqlSugar 提供了一個SimpleClient,這裏面有不少能夠直接拿來用的方法,並且這個是一個泛型類。也就是說咱們可使用它對單個實體類進行操做,這在開發中很重要。數據庫
對於一個程序而言,數據就像是血液同樣重要。對於ORM框架,插入是一切來源的基礎。因此咱們先來看看SqlSugar的插入是怎樣的吧:express
public bool Insert(T insertObj);
public bool InsertRange(T[] insertObjs);
public bool InsertRange(List<T> insertObjs);
這是SqlSugar在SimpleClient裏提供的兩個默認插入方法,一個是插入單個實體對象,一個是插入一組對象。app
默認狀況下,SqlSugar插入並不會將主鍵返回給數據。若是後續操做須要當前數據的主鍵,則能夠調用另一個方法:框架
public int InsertReturnIdentity(T insertObj);
經過這個方法能夠獲取一個默認的int類型主鍵值。asp.net
SqlSugar還有一種插入模式,經過AsInsertable返回一個 IInsertable泛型接口:ide
public IInsertable<T> AsInsertable(T insertObj);
public IInsertable<T> AsInsertable(T[] insertObjs);
public IInsertable<T> AsInsertable(List<T> insertObjs);
這種模式與SimpleClient的普通插入模式不一樣,它並不會直接執行插入動做,須要手動調用並執行插入動做:this
int ExecuteCommand();
執行動做,而後返回受影響的行數。spa
bool ExecuteCommandIdentityIntoEntity();
執行動做,而後將主鍵插入實體對象,返回插入結果。執行完成後,主鍵數據保存到實體示例中。
long ExecuteReturnBigIdentity();
int ExecuteReturnIdentity();
執行動做,而後返回主鍵值,不會更新實體。
有一點值得特別注意:
全部會返回主鍵的插入都只針對單個數據,若是一次插入多個數據,並不會返回主鍵信息也沒法將主鍵信息更新入實體中。
以上都是全列插入,SqlSugar還提供了只插入部分列和忽略某些列兩種模式:
IInsertable<T> InsertColumns(Expression<Func<T, object>> columns);// 知足條件的插入,其餘列則不插入
IInsertable<T> InsertColumns(params string[] columns);//插入指定列名
IInsertable<T> IgnoreColumns(Expression<Func<T, object>> columns);// 忽略知足條件的列,插入其餘列
IInsertable<T> IgnoreColumns(params string[] columns);// 忽略這幾個列
IInsertable<T> IgnoreColumns(bool ignoreNullColumn, bool isOffIdentity = false);//指定是否忽略Null列,並是否強制插入主鍵
介紹完插入,那麼來介紹一下更新。正所謂,沒有更新數據就是一灘死水,有了更新數據纔有了變化。因此,就讓咱們來看看如何優雅的更新數據吧:
先來兩個最簡單的:
public bool Update(T updateObj);
public bool UpdateRange(T[] updateObjs);
public bool UpdateRange(List<T> updateObjs);
傳入實體,直接更新到數據庫中,須要注意的是這種更新模式只須要保證主鍵有值,且與之對應便可。
public bool Update(Expression<Func<T, T>> columns, Expression<Func<T, bool>> whereExpression);
這是另外一種條件更新,會更新知足whereExpression的全部元素,更新示例:
personClient.Update(p=>new Person
{
Age = 1
}, p=>p.Id == 1);
columns須要返回一個要更新的對象的屬性列,也就是在columns中設置須要更新的內容。
一樣,經過AsUpdateable開啓高級模式:
public IUpdateable<T> AsUpdateable(T[] updateObjs);
public IUpdateable<T> AsUpdateable(T updateObj);
public IUpdateable<T> AsUpdateable(List<T> updateObjs);
而後能夠針對這些今天更多的操做:
int ExecuteCommand();
返回命令執行影響的行數
bool ExecuteCommandHasChange();
返回是否有變化,也就是影響行數是否大於0。
只更新某些列:
IUpdateable<T> SetColumns(Expression<Func<T, bool>> columns);
更新示例:
personClient.AsUpdateable(d).SetColumns(t=>t.Age ==2).ExecuteCommand();
傳入一個lambda表達式,使數據知足lambda表達式。要求lambda表達式只能用 == 來判斷列是否等於某個值。
IUpdateable<T> SetColumns(Expression<Func<T, T>> columns);
IUpdateable<T> UpdateColumns(params string[] columns);
IUpdateable<T> UpdateColumns(Expression<Func<T, object>> columns);
傳入要更新的實際列名。其中 object 用來接一個匿名對象,其中屬性名字就是要更新的值。
不更新某些列
IUpdateable<T> IgnoreColumns(params string[] columns);// 忽略傳入的列名
IUpdateable<T> IgnoreColumns(Expression<Func<T, object>> columns);// 用匿名對象表示要忽略的列名
IUpdateable<T> IgnoreColumns(bool ignoreAllNullColumns, bool isOffIdentity = false, bool ignoreAllDefaultValue = false);// 設置是否忽略Null列,是否強制更新主鍵,是否忽略全部默認值列
條件更新
IUpdateable<T> Where(Expression<Func<T, bool>> expression);
IUpdateable<T> Where(string fieldName, string conditionalType, object fieldValue);
IUpdateable<T> Where(string whereSql, object parameters = null);
IUpdateable<T> WhereColumns(Expression<Func<T, object>> columns);
IUpdateable<T> WhereColumns(string columnName);
IUpdateable<T> WhereColumns(string[] columnNames);
來,簡單猜一猜這幾個是什麼意思呢?
能夠說很簡單明瞭的幾種條件設置模式,lambda表示篩選更新數據,字段值判斷條件更新。
其中 conditionType的值,推薦使用 ConditionalType
枚舉的值。
在實際開發中可能會遇到插入或更新是走的一個方法,因此咱們就要尋找一個能夠直接更新或插入的方法。SqlSugar爲此提供瞭解決方案:
ISaveable<T> Saveable<T>(T saveObject) where T : class, new();
ISaveable<T> Saveable<T>(List<T> saveObjects) where T : class, new();
不過這個方法是在SugarClient裏,咱們能夠經過:
public ISqlSugarClient AsSugarClient();
在SimpleClient中得到 與之關聯的SugarClient對象。
關於更新或插入判斷標準是,主鍵是否有值。若是主鍵有值且在數據庫中存在該條記錄,則執行更新,不然執行插入。
刪除在實際開發過程當中是一個很是重要的功能點,因此如何快速有效的刪除數據也是一件很重要的事。那麼,就來看看如何執行刪除吧:
public bool Delete(Expression<Func<T, bool>> whereExpression);
public bool Delete(T deleteObj);
public bool DeleteById([Dynamic] dynamic id);
public bool DeleteByIds([Dynamic(new[] { false, true })] dynamic[] ids);
刪除沒有其餘須要注意的地方,第一個是條件刪除,全部知足條件的都要刪除。第二個刪除單個對象,後面兩個根據主鍵刪除對象。
悄悄吐槽一下,主鍵的地方用object會比較好一點,由於動態對象會增長一次裝箱拆箱的過程。
固然了,刪除也有AsDeleteable方法。IDeleteable接口特別提供了根據sql語句刪除的方法,除此以外沒有別的須要注意的地方了。
一個好的ORM框架,至少五分功力在查詢上,如何更快更準的查詢成爲了如今開發對ORM框架的要求。同時簡單易用更是程序員對ORM的指望。
那麼咱們來看看SqlSugar在查詢上的功力吧:
public bool IsAny(Expression<Func<T, bool>> whereExpression);// 查詢是否存在符合條件的數據
public int Count(Expression<Func<T, bool>> whereExpression);// 獲取知足條件的數量
public T GetById([Dynamic] dynamic id);//根據主鍵獲取一個實例
public bool IsAny(Expression<Func<T, bool>> whereExpression);//返回知足條件的一個對象
public List<T> GetList();// 以List的形式返回全部數據
public List<T> GetList(Expression<Func<T, bool>> whereExpression);//返回符合條件的全部數據
分頁獲取數據:
public List<T> GetPageList(Expression<Func<T, bool>> whereExpression, PageModel page);
public List<T> GetPageList(Expression<Func<T, bool>> whereExpression, PageModel page, Expression<Func<T, object>> orderByExpression = null, OrderByType orderByType = OrderByType.Asc);
public List<T> GetPageList(List<IConditionalModel> conditionalList, PageModel page);
public List<T> GetPageList(List<IConditionalModel> conditionalList, PageModel page, Expression<Func<T, object>> orderByExpression = null, OrderByType orderByType = OrderByType.Asc);
其中IConditionModel是一個空的接口,用來定義規範查詢規範,實際上使用的是類:
public class ConditionalModel: IConditionalModel
{
public ConditionalModel()
{
this.ConditionalType = ConditionalType.Equal;
}
public string FieldName { get; set; }
public string FieldValue { get; set; }
public ConditionalType ConditionalType { get; set; }
public Func<string,object> FieldValueConvertFunc { get; set; }
}
那麼,咱們看一下 ConditionType,定義了各類判斷依據:
public enum ConditionalType
{
Equal=0,
Like=1,
GreaterThan =2,
GreaterThanOrEqual = 3,
LessThan=4,
LessThanOrEqual = 5,
In=6,
NotIn=7,
LikeLeft=8,
LikeRight=9,
NoEqual=10,
IsNullOrEmpty=11,
IsNot=12,
NoLike = 13,
}
那麼咱們簡單看一下 使用IConditionModel進行分頁是怎樣的效果:
var list = personClient.GetPageList(new List<IConditionalModel>
{
new ConditionalModel
{
FieldName = "Age",
FieldValue = "3",
ConditionalType = ConditionalType.LessThan
}
}, pageModel);
生成以下SQL語句:
SELECT COUNT(1) FROM (SELECT `Id`,`Name`,`Age` FROM `Person` WHERE Age < @ConditionalAge0 ) CountTable
SELECT `Id`,`Name`,`Age` FROM `Person` WHERE Age < @ConditionalAge0 LIMIT 0,2
能夠看出二者並無區別,只不過是不一樣的查詢習慣。
按照以前的習慣,到目前應該能夠結束了。可是SqlSugar還有一些很重要的地方沒有介紹,因此就加個下期預告
下一篇將爲你們分析SqlSugar的一些更高級的內容,查詢的高級模式、事務以及批量操做
好,總結一下這一篇,咱們在這一篇看到了SqlSugar在增刪改查上的亮點,能夠說更貼合實際業務需求開發。嗯,悄悄給個贊。
再有三篇的內容《C# 數據操做系列》就要完結了。從下一系列開始,就要步入工做中最重要的技術棧了:Asp.net Core。這是能夠寫入簡歷的。嗯,沒錯。下一系列計劃以實戰的形式介紹asp.net core的知識點和設置。