國產優秀ORM框架SqlSugar的使用方法,實例解析

来源:https://www.cnblogs.com/hanbing81868164/archive/2023/11/27/17858332.html
-Advertisement-
Play Games

SqlSugar是一個輕量級ORM框架,專門用於.NET平臺,可以簡化資料庫操作,提高開發效率。它支持多種資料庫,包括MySQL、SqlServer、Oracle等,提供了豐富的功能和靈活的配置選項。 下麵將詳細介紹SqlSugar的使用方法及其相比其他ORM框架的優點。 一、SqlSugar的安裝 ...


SqlSugar是一個輕量級ORM框架,專門用於.NET平臺,可以簡化資料庫操作,提高開發效率。它支持多種資料庫,包括MySQL、SqlServer、Oracle等,提供了豐富的功能和靈活的配置選項。

下麵將詳細介紹SqlSugar的使用方法及其相比其他ORM框架的優點。

一、SqlSugar的安裝和配置

1.使用NuGet包管理器安裝SqlSugar。 在Visual Studio中,右擊項目,選擇“管理NuGet程式包”,搜索“SqlSugar”,選擇安裝。

2.配置資料庫連接字元串。 在app.config或web.config文件中,添加如下配置節:

<connectionStrings>
 <add name="DefaultConnection" connectionString="Data Source=127.0.0.1;Initial Catalog=TestDB;User ID=sa;Password=123456;" providerName="System.Data.SqlClient" />
</connectionStrings>

3.創建實體類。 創建一個類,用於映射資料庫表的結構,例如:

public class User
{
         public int Id { get; set; }
         public string Name { get; set; }
         public int Age { get; set; }
}

二、SqlSugar的基本用法

1.初始化SqlSugar對象。

using SqlSugar;
...
var connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString;
var db = new SqlSugarClient(new ConnectionConfig()
{
       ConnectionString = connectionString,
       DbType = DbType.SqlServer,
       IsAutoCloseConnection = true,
       InitKeyType = InitKeyType.Attribute
});

2.增刪改查操作。

// 插入數據
var user = new User { Name = "張三", Age = 20 };
var id = db.Insertable(user).ExecuteReturnIdentity();

// 更新數據
user.Age = 25;
db.Updateable(user).ExecuteCommand();

// 刪除數據
db.Deleteable<User>().Where(u => u.Id == id).ExecuteCommand();

// 查詢數據
var userList = db.Queryable<User>().ToList();

3.高級查詢。

// 條件查詢
var userList = db.Queryable<User>().Where(u => u.Age > 18).ToList();

// 分頁查詢
var userList = db.Queryable<User>().Where(u => u.Age > 18).ToPageList(1, 10, ref totalCount);

// 排序查詢
var userList = db.Queryable<User>().OrderBy(u => u.Age, OrderByType.Desc).ToList();

// 連表查詢
var userList = db.Queryable<User, Order>((u, o) => new JoinQueryInfos(JoinType.Left, u.Id == o.UserId))
 .Select((u, o) => new { u.Name, o.OrderNo })
 .ToList();

4.事務操作。

// 開啟事務
db.Ado.BeginTran();

try
{
       // 執行多個操作
       db.Insertable(user1).ExecuteCommand();
       db.Insertable(user2).ExecuteCommand();

       // 提交事務
       db.Ado.CommitTran();
}
catch (Exception ex)
{
         // 回滾事務
         db.Ado.RollbackTran();
}

三、SqlSugar相比其他ORM框架的優點

  1. 簡單易用。 SqlSugar提供了簡潔的API,可以快速上手,減少學習成本。
  2. 性能優越。 SqlSugar採用了一系列優化措施,如緩存、預編譯等,提高了資料庫操作的性能。
  3. 支持多種資料庫。 SqlSugar支持多種資料庫,可以輕鬆切換資料庫類型,減少了對資料庫的依賴。
  4. 提供豐富的功能。 SqlSugar提供了豐富的功能,如分頁查詢、事務操作、連接查詢等,滿足了各種複雜的業務需求。
  5. 提供靈活的配置選項。 SqlSugar提供了許多配置選項,可以根據需求進行靈活配置,滿足不同項目的需求。

以上是對SqlSugar的詳細介紹及其相比其他ORM框架的優點。通過使用SqlSugar,可以簡化資料庫操作,提高開發效率。希望以上內容對您有所幫助。

【示例源代碼】

using System;
using System.Configuration;
using SqlSugar;

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
}

class Program
{
    static void Main(string[] args)
    {
        var connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString;
        var db = new SqlSugarClient(new ConnectionConfig()
        {
            ConnectionString = connectionString,
            DbType = DbType.SqlServer,
            IsAutoCloseConnection = true,
            InitKeyType = InitKeyType.Attribute
        });

        var user = new User { Name = "張三", Age = 20 };
        var id = db.Insertable(user).ExecuteReturnIdentity();

        user.Age = 25;
        db.Updateable(user).ExecuteCommand();

        db.Deleteable<User>().Where(u => u.Id == id).ExecuteCommand();

        var userList = db.Queryable<User>().ToList();

        Console.WriteLine("查詢結果:");
        foreach (var u in userList)
        {
            Console.WriteLine($"Id: {u.Id}, Name: {u.Name}, Age: {u.Age}");
        }

        Console.ReadLine();
    }
}

以上是一個簡單的使用SqlSugar的示例代碼。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文: https://openaigptguide.com/what-is-openai/ OpenAI 是一家人工智慧研究公司,成立於2015年,總部位於美國舊金山。目前,OpenAI由創始人Sam Altman、首席技術官Ilya Sutskever、首席執行官Ilya Sutskever(同 ...
  • Flask 框架提供了強大的 Session 模塊組件,為 Web 應用實現用戶註冊與登錄系統提供了方便的機制。結合 Flask-WTF 表單組件,我們能夠輕鬆地設計出用戶友好且具備美觀界面的註冊和登錄頁面,使這一功能能夠直接應用到我們的項目中。本文將深入探討如何通過 Flask 和 Flask-W... ...
  • 作者:京東零售 薑波 來源:京東雲開發者社區 各位小伙伴在字元串拼接時應該都見過下麵這種提示: 內容翻譯:報告StringBuffer、StringBuilder或StringJoiner的任何用法,這些用法可以用單個java.lang.String串聯來替換。使用字元串串聯可以使代碼更短、更簡單。 ...
  • JsonPath是一種能夠提取部分JSON文檔屬性、對象、數組的語法,支持條件過濾、數學運算、字元串處理等功能。JsonPath與JSON文檔就像 XPath 表達式與 XML 文檔結合使用一樣。 ...
  • 這段筆記詳細介紹了SpringMVC控制器開發的不同方面,主要圍繞控制器如何接收客戶端請求參數展開討論。它包括了不同接收請求參數的方式,從基於Servlet API的方式到簡單變數、POJO對象、一組簡單變數、一組POJO對象的接收方式,以及@RequestParam註解的使用方法。還涉及了中文請求... ...
  • 今天我們學習了網路編程和多線程技術的寫法區別。我們主要關註了在Java中使用socket和多線程結合實現伺服器處理多個客戶端連接的阻塞IO的方法,以及在Python中使用multiprocessing模塊創建多線程的方式。通過一個實例來說明瞭這些概念,並指出了需要註意的問題。其實瞭解了這些基本用法後... ...
  • Autofac是一個功能強大的依賴註入容器,它提供了一種簡單和靈活的方式來管理對象之間的依賴關係。下麵是Autofac的一些優點: 簡單易用:Autofac提供了一種直觀和簡潔的方式來註冊和解析依賴項。它的API設計得非常易於理解和使用,使得開發人員可以輕鬆地配置和管理依賴關係。 靈活性:Autof ...
  • 引言 如題,在VS中如何調試 .Net 源碼呢? 一般來說,VS2022,都是預設啟用 F12 轉到定義能夠看到源碼,如果大家發現自己無法使用 F12 查看源碼,可以在 "工具" -> "選項" -> "文本編輯器" -> "C#" -> "高級" -> "轉到定義",勾選所有選項就對了。 但是光以 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...