.NET CORE 下如何使用國產數據庫進行 開發

主流國產數據庫

隨着貿易戰的升級 ,自主研發和知識產權也是一個大的趨勢,達夢和人大金倉是國產數據庫中比較主流的html

 

一、達夢數據庫

更接近Oracle,更偏向自主研發,對開發人員友好度不如金倉 git

達夢公司在總結DM系列產品研發與應用經驗的基礎上,堅持開放創新、簡潔實用的理念,歷經五年匠心打磨,推出的新一代自研數據庫。DM8吸取借鑑當前先...github

下載地址:sql

http://www.dameng.com/down.aspx?TypeId=11&FId=t14:11:14數據庫

安裝步驟:json

選擇Windows版本直接安裝就行能夠了,安裝時須要受權跳過便可數組

二、人大金倉數據庫

基本上和PgSql如出一轍更貼近開發功能也繼承了pgsql全部功能,對開發人員比較友好併發

Kingbase ES是面向事務處理類、兼顧分析類應用領域的新型數據庫產品,致力於解決高併發、高可靠數據存儲計算問題,是一款面向企事業單位管理信息系統、業務及生產系統、框架

決策支持系統等量身打造的承載數據庫,目前功能性能已全面升級,是真正具備高成熟度的數據庫產品。高併發

下載地址:

https://www.kingbase.com.cn/index/service.html

安裝步驟:

1.選擇 金倉數據庫管理系統

二、選擇 安裝文件包和受權文件包 

 

ORM 框架選擇

既然是國產數據庫那麼數據庫ORM也應該選擇國產ORM ,SqlSugar ORM框架是一直更新到如今誕生最先的 國產ORM,出身於2014年距離如今有6年多的時間

源碼和國產數據庫操做DEMO下載地址

https://github.com/sunkaixuan/SqlSugar 

 

建立項目

建立.NET Core項目

Nuget 只須要安裝SqlSugarCore 就能夠操做咱們的國產數據庫了

 

建立數據庫對象

鏈接字符串格式

達夢  PORT=5236;DATABASE=DAMENG;HOST=localhost;PASSWORD=SYSDBA;USER ID=SYSDBA

人大金倉 Server=127.0.0.1;Port=54321;UID=SYSTEM;PWD=system;database=SQLSUGAR4XTEST1

具體代碼以下:


var Db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = Config.ConnectionString, DbType = DbType.Dm,//達夢數據庫 IsAutoCloseConnection = true, InitKeyType = InitKeyType.Attribute, AopEvents = new AopEvents() { OnLogExecuting = (sql, p) => { Console.WriteLine(sql); } } });
 var Db2 = new SqlSugarClient(new ConnectionConfig()
            {
                ConnectionString = Config.ConnectionString,
                DbType = DbType.Kdbndp,//人大金倉數據庫
                IsAutoCloseConnection = true,
                InitKeyType = InitKeyType.Attribute,
                AopEvents = new AopEvents()
                {
                    OnLogExecuting = (sql, p) =>
                    {
                        Console.WriteLine(sql);
                    }
                }
            });

 

建立實體

  [SugarTable("STudent")]
   public class Student
    {
        [SugarColumn(IsPrimaryKey = true, IsIdentity = true)]
        public int Id { get; set; }
        public int? SchoolId { get; set; }
        public string Name { get; set; }
        public DateTime? CreateTime { get; set; }
        [SugarColumn(IsIgnore=true,NoSerialize =true)]
        public int TestId { get; set; }
    }

    

使用ORM操做數據庫

具體用法和其它數據庫操做如出一轍

//查詢
var getAll = db.Queryable<Student>().ToList();//查詢全部 var getFirst = db.Queryable<Student>().First(it=>it.Id=1);//查詢單條 var getAllNoLock = db.Queryable<Student>().With(SqlWith.NoLock).ToList();//SqlServer裏面的withnolock var getByPrimaryKey = db.Queryable<Student>().InSingle(2);//根據主鍵查詢 var sum = db.Queryable<Student>().Sum(it=>it.Id);//查詢總和 var isAny = db.Queryable<Student>().Where(it=>it.Id==-1).Any();//是否存在 var isAny2 = db.Queryable<Student>().Any(it => it.Id == -1); var getListByRename = db.Queryable<School>().AS("Student").ToList(); var getByWhere = db.Queryable<Student>().Where(it => it.Id == 1 || it.Name == "a").ToList(); var list= db.Queryable<Student>().AS("student2019").ToList();//select * from student2019 var list2 = db.Queryable<Order>().Where(it =>it.Name.Contains("jack")).ToList();//模糊查詢

 

返回List

List<Student> list = db.Queryable<Student>().ToList();

  

返回第一個實體

Student item = db.Queryable<Student>().First(it=>it.Id==1);

 

返回DataTable

DataTable dataTable = db.Queryable<Student>().Select(it => it.Id).ToDataTable();

 

返回Json

var json = db.Queryable<Student>().ToJson();


返回數組

List<int> listInt=db.Queryable<Student>().Select(it => it.Id).ToList();


返回匿名對象

var dynamic = db.Queryable<Student>().Select<dynamic>().ToList();

 

返回到新類

var viewModel = db.Queryable<Student, School, DataTestInfo>((st, sc, di) => new JoinQueryInfos(
JoinType.Left, st.SchoolId == sc.Id,
JoinType.Left, st.Name == di.String
))
.Select<ViewModelStudent>().ToList();

 

多表返回匿名對象

var newDynamic = db.Queryable<Student, School, DataTestInfo>((st, sc, di) => new JoinQueryInfos(
JoinType.Left, st.SchoolId == sc.Id,
JoinType.Left, st.Name == di.String
)) .Select((st,sc,di)=>new { name=st.Name,scid=sc.Id }).ToList();

 

手動返回到新類

var newClass= db.Queryable<Student, School, DataTestInfo>((st, sc, di) => new JoinQueryInfos(
JoinType.Left, st.SchoolId == sc.Id,
JoinType.Left, st.Name == di.String
)) .Select((st,sc,di)=>new ClassName{ name=st.Name,scid=sc.Id }).ToList();

 

多表查一表

var oneClass = db.Queryable<Order, OrderItem, Custom>((o, i, c) => new JoinQueryInfos(
JoinType.Left, o.Id == i.OrderId,
JoinType.Left, o.CustomId == c.Id
))
.Select((o, i, c) => c).ToList();

 

多表返回2表

var twoClass = db.Queryable<Order, OrderItem, Custom>((o, i, c) => new JoinQueryInfos(
JoinType.Left, o.Id == i.OrderId,
JoinType.Left, o.CustomId == c.Id
))
.Select((o, i, c) => new { o,i}).ToList()

 

返回字典集合

List<Dictionary<string, object>> ListDic = db.Queryable<Student, School, DataTestInfo>((st, sc, di) => new JoinQueryInfos(
JoinType.Left, st.SchoolId == sc.Id,
JoinType.Left, st.Name == di.String
)).Select<ExpandoObject>().ToList().Select(it => it.ToDictionary(x => x.Key, x => x.Value)).ToList(); ;

 

 

刪除
db.Deleteable<Student>().In(1).ExecuteCommand();

 

更新
var result= db.Updateable(updateObj).ExecuteCommand();

 

插入
db.Insertable(insertObj).ExecuteCommand(); 

 

除了 增刪查改,SqlSugar ORM 還支持不少功能,就不一一演示,一篇文章介紹不完。 

 

源碼 DEMO下載地址:

https://github.com/sunkaixuan/SqlSugar

謝謝支持

相關文章
相關標籤/搜索