一個可用於生產項目 基於 .NET 6 自研ORM

来源:https://www.cnblogs.com/China-Mr-zhong/archive/2023/04/22/17342895.html
-Advertisement-
Play Games

Fast Framework 作者 Mr-zhong 代碼改變世界.... 一、前言 Fast Framework 基於NET6.0 封裝的輕量級 ORM 框架 支持多種資料庫 SqlServer Oracle MySql PostgreSql Sqlite 優點: 體積小、可動態切換不同實現類庫、 ...


Fast Framework

作者 Mr-zhong

代碼改變世界....

一、前言

Fast Framework 基於NET6.0 封裝的輕量級 ORM 框架 支持多種資料庫 SqlServer Oracle MySql PostgreSql Sqlite

優點: 體積小、可動態切換不同實現類庫、原生支持微軟特性、流暢API、使用簡單、性能高、模型數據綁定採用 委托、強大的表達式解析、支持多種子查詢可實現較為複雜查詢、源代碼可讀性強。

缺點:目前僅支持Db Frist Code Frist 後續迭代。

開源地址 https://github.com/China-Mr-zhong/Fast.Framework (唯一)

目前作者已使用該框架應用多個生產項目

個別亮點功能:數值類型綁定自動格式化小數點後面多餘的0、表達式參數名稱自動編排 無需強制統一參數名稱

本作者不提供任何性能對比數據,請各位感興趣的自行測試,對比前建議預熱連接

二、項目明細
名稱 說明
Fast.Framework 框架主項目
Fast.Framework.Logging 基於微軟介面實現的文件日誌(非必要可不引用)
Fast.Framework.Test 控制台測試項目
Fast.Framework.UnitTest 單元測試項目
Fast.Framework.Web.Test Web測試項目
三、核心對象
  • Ado 原生Ado對象

                    IAdo ado = new AdoProvider(new DbOptions()
                    {
                        DbId = "1",
                        DbType = DbType.MySQL,
                        ProviderName = "MySqlConnector",
                        FactoryName = "MySqlConnector.MySqlConnectorFactory,MySqlConnector",
                        ConnectionStrings = "server=localhost;database=Test;user=root;pwd=123456789;port=3306;min pool size=3;max pool size=100;connect timeout=30;"
                    });
    
  • DbContext 支持多租戶 支持切換不同Ado實現類庫 設置 ProviderName和FactoryName 即可

                    IDbContext db = new DbContext(new List<DbOptions>() {
                    new DbOptions()
                    {
                        DbId = "1",
                        DbType = DbType.MySQL,
                        ProviderName = "MySqlConnector",
                        FactoryName = "MySqlConnector.MySqlConnectorFactory,MySqlConnector",
                        ConnectionStrings = "server=localhost;database=Test;user=root;pwd=123456789;port=3306;min pool size=3;max pool size=100;connect timeout=30;"
                    }});
    
  • DbOptions Json文件配置格式

    "DbOptions": [
        {
          "DbId": 1,
          "DbType": "SQLServer",
          "ProviderName": "System.Data.SqlClient",
          "FactoryName": "System.Data.SqlClient.SqlClientFactory,System.Data",
          "ConnectionStrings": "server=localhost;database=Test;user=sa;pwd=123456789;min pool size=3;max pool size=100;connect timeout=120;"
        }]
    
  • Asp.net Core 依賴註入

    // 註冊服務 
    var builder = WebApplication.CreateBuilder(args);
    
    // 添加資料庫上下文
    builder.Services.AddFastDbContext();
    
    // 從Json配置文件載入資料庫選項
    builder.Services.Configure<List<DbOptions>>(builder.Configuration.GetSection("DbOptions"));
    
    // 產品服務類 通過構造方法註入
    public class ProductService
    {
        /// <summary>
        /// 資料庫
        /// </summary>
        private readonly IDbContext db;
    
        /// <summary>
        /// 構造方法
        /// </summary>
        /// <param name="db">資料庫</param>
        public ProductService(IDbContext db)
        {
            this.db = db;
        }
    }
    
四、插入
  • 實體對象插入

                var product = new Product()
                {
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                var result = db.Insert(product).Exceute();
                Console.WriteLine($"實體對象插入 受影響行數 {result}");
    
  • 實體對象插入並返回自增ID 僅支持 SQLServer MySQL SQLite

                var product = new Product()
                {
                    ProductCode = "1001",
                    ProductName = "測試產品1"
                };
                var result = db.Insert(product).ExceuteReturnIdentity();
                Console.WriteLine($"實體對象插入 返回自增ID {result}");
    
  • 實體對象列表插入

                var list = new List<Product>();
                for (int i = 0; i < 2100; i++)
                {
                    list.Add(new Product()
                    {
                        ProductCode = $"編號{i + 1}",
                        ProductName = $"名稱{i + 1}"
                    });
                }
                var result = db.Insert(list).Exceute();
                Console.WriteLine($"實體對象列表插入 受影響行數 {result}");
    
  • 匿名對象插入

                var obj = new
                {
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                //註意:需要使用As方法顯示指定表名稱
                var result = db.Insert(obj).As("Product").Exceute();
                Console.WriteLine($"匿名對象插入 受影響行數 {result}");
    
  • 匿名對象列表插入

                var list = new List<object>();
                for (int i = 0; i < 2100; i++)
                {
                    list.Add(new
                    {
                        ProductCode = $"編號{i + 1}",
                        ProductName = $"名稱{i + 1}"
                    });
                }
                //註意:需要使用As方法顯示指定表名稱
                var result = db.Insert(list).As("Product").Exceute();
                Console.WriteLine($"匿名對象列表插入 受影響行數 {result}");
    
  • 字典插入

                var product = new Dictionary<string, object>()
                {
                    {"ProductCode","1001"},
                    { "ProductName","測試商品1"}
                };
                var result = db.Insert(product).As("Product").Exceute();
                Console.WriteLine($"字典插入 受影響行數 {result}");
    
  • 字典列表插入

                var list = new List<Dictionary<string, object>>();
                for (int i = 0; i < 2100; i++)
                {
                    list.Add(new Dictionary<string, object>()
                    {
                        {"ProductCode","1001"},
                        { "ProductName","測試商品1"}
                     });
                }
                var result = db.Insert(list).As("Product").Exceute();
                Console.WriteLine($"字典列表插入 受影響行數 {result}");
    
五、刪除
  • 實體對象刪除

                var product = new Product()
                {
                    ProductId = 1,
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                //註意:必須標記KeyAuttribute特性 否則將拋出異常
                var result = db.Delete(product).Exceute();
                Console.WriteLine($"實體刪除 受影響行數 {result}");
    
  • 無條件刪除

                var result = db.Delete<Product>().Exceute();
                Console.WriteLine($"無條件刪除 受影響行數 {result}");
    
  • 表達式刪除

                var result = await db.Delete<Product>().Where(w => w.ProductId == 1).ExceuteAsync();
                Console.WriteLine($"條件刪除 受影響行數 {result}");
    
  • 特殊刪除

    			      //特殊用法 如需單個條件或多個可搭配 WhereColumn或WhereColumns方法
                var result = await db.Delete<object>().As("Product").ExceuteAsync();
                Console.WriteLine($"無實體刪除 受影響行數 {result}");
    
六、更新
  • 實體對象更新

                var product = new Product()
                {
                    ProductId = 1,
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                //註意:標記KeyAuttribute特性屬性或使用Where條件,為了安全起見全表更新將必須使用Where方法
                var result = db.Update(product).Exceute();
                Console.WriteLine($"對象更新 受影響行數 {result}");
    
  • 指定列更新

                var result = db.Update<Product>(new Product() { ProductCode = "1001", ProductName = "1002" }).Columns("ProductCode", "ProductName").Exceute();
    						// 欄位很多的話可以直接new List<string>(){"列1","列2"}
    
  • 忽略列更新

                var result = db.Update<Product>(new Product() { ProductCode = "1001", ProductName = "1002" }).IgnoreColumns("Custom1").Exceute();
                // 同上使用方法一樣
    
  • 實體對象列表更新

                var list = new List<Product>();
                for (int i = 0; i < 2022; i++)
                {
                    list.Add(new Product()
                    {
                        ProductCode = $"編號{i + 1}",
                        ProductName = $"名稱{i + 1}"
                    });
                }
                //註意:標記KeyAuttribute特性屬性或使用WhereColumns方法指定更新條件列
                var result = db.Update(list).Exceute();
                Console.WriteLine($"對象列表更新 受影響行數 {result}");
    
  • 匿名對象更新

                var obj = new
                {
                    ProductId = 1,
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                //註意:需要顯示指定表名稱 以及更新條件 使用 Where或者WhereColumns方法均可
                var result = db.Update(obj).As("product").WhereColumns("ProductId").Exceute();
                Console.WriteLine($"匿名對象更新 受影響行數 {result}");
    
  • 匿名對象列表更新

                var list = new List<object>();
                for (int i = 0; i < 2022; i++)
                {
                    list.Add(new
                    {
                        ProductId = i + 1,
                        ProductCode = $"編號{i + 1}",
                        ProductName = $"名稱{i + 1}"
                    });
                }
                //由於是匿名對象需要顯示指定表名稱,使用WhereColumns方法指定更新條件列
                var result = db.Update(list).As("Product").WhereColumns("ProductId").Exceute();
                Console.WriteLine($"匿名對象列表更新 受影響行數 {result}");
    
  • 字典更新

                var product = new Dictionary<string, object>()
                {
                    { "ProductId",1},
                    {"ProductCode","1001"},
                    { "ProductName","測試商品1"}
                };
                var result = db.Update(product).As("Product").WhereColumns("ProductId").Exceute();
                Console.WriteLine($"字典更新 受影響行數 {result}");
    
  • 字典列表更新

                var list = new List<Dictionary<string, object>>();
                for (int i = 0; i < 2022; i++)
                {
                    list.Add(new Dictionary<string, object>()
                    {
                        { "ProductId",i+1},
                        {"ProductCode",$"更新編號:{i+1}"},
                        { "ProductName",$"更新商品:{i + 1}"}
                    });
                }
                var result = db.Update(list).As("Product").WhereColumns("ProductId").Exceute();
                Console.WriteLine($"字典列表更新 受影響行數 {result}");
    
  • 指定條件更新

                var product = new Product()
                {
                    ProductId = 1,
                    ProductCode = "1001",
                    ProductName = "測試商品1"
                };
                var result = db.Update(product).Where(p => p.ProductId == 100).Exceute();
                Console.WriteLine($"表達式更新 受影響行數 {result}");
    
  • 併發更新 樂觀鎖-版本控制

                    //註意:僅支持非列表更新 版本列數據類型僅支持 object、string、Guid 時間類型存在精度丟失所以不做支持
    				var obj = db.Query<Product>().Where(w => w.ProductId == 1).Frist();
                    obj.Custom1 = "測試版本控制修改";
    				//參數為 true 更新失敗將拋出異常
                    var result = db.Update(obj).ExceuteWithOptLock(true);
    
七、查詢
  • 單一查詢

                var data = db.Query<Product>().First();
    
  • 列表查詢

                var data = db.Query<Product>().ToList();
    
  • 返回單個字典

                var data = db.Query<Product>().ToDictionary();
    
  • 返回字典列表

                var data = db.Query<Product>().ToDictionaryList();
    
  • 分頁查詢

                //分頁查詢不返回總數
                var data = db.Query<Product>().ToPageList(1,100);
                //分頁查詢返回總數
    			var total = 0;//定義總數變數
    			var data = db.Query<Product>().ToPageList(1, 1, ref total);
                Console.WriteLine($"總數:{total}");
    
  • 計數查詢

                var data = db.Query<Product>().Count();
    
  • 任何查詢

                var data = db.Query<Product>().Any();
    
  • 條件查詢

                var data = db.Query<Product>().Where(w => w.ProductId == 1).ToList;
    
  • Like 查詢

                var data = db.Query<Product>().Where(w => w.ProductName.StartsWith("左模糊") || w.ProductName.EndsWith("右模糊") || w.ProductName.Contains("全模糊")).ToList();
    
  • Not Like查詢

    var data = db.Query<Product>().Where(w => !w.ProductName.StartsWith("左模糊") || !w.ProductName.EndsWith("右模糊") || !w.ProductName.Contains("全模糊")).ToList();
    
  • Select查詢 (選擇欄位)

                var data = db.Query<Product>().Select(s => new
                {
                    s.ProductId,
                    s.ProductName
                }).ToList();
    
  • Select查詢 (Case When)

                    var data = db.Query<Product>().Select(s => new
                    {
                        CaseTest1 = SqlFunc.Case(s.Custom1).When("1").Then("xx1").When("2").Then("xx2").Else("xx3").End(),
                        CaseTest2 = SqlFunc.CaseWhen<string>(s.Custom1 == "1").Then("xx1").When(s.Custom1 == "2").Then("xx2").Else("xx3").End()
                    }).ToList();
    
  • 分組查詢

                var data = db.Query<Product>().GroupBy(s => new
                {
                    s.ProductId,
                    s.ProductName
                }).ToList();
    
  • 分組聚合查詢

                var sql = db.Query<Order>().InnerJoin<OrderDetail>((a, b) => a.OrderId == b.OrderId).GroupBy((a, b) => new
                {
                    a.OrderCode
                }).Select((a, b) => new
                {
                    a.OrderCode,
                    Sum_Qty = SqlFunc.Sum(b.Qty)//支持嵌套
                }).ToList();
    
  • 排序查詢

                var data = db.Query<Product>().OrderBy(s => new
                {
                    s.CreateTime
                }).ToList();
                //這是多個欄位排序使用方法 還有其它重載方法
    
  • Having查詢

                var data = db.Query<Product>().GroupBy(s => new
                {
                    s.ProductId,
                    s.ProductName
                }).Having(s => SqlFunc.Count(s.ProductId) > 1).ToList();
                //必須先使用GroupBy方法 懂得都懂
    
  • 聯表查詢

                var data = db.Query<Product>().LeftJoin<Class1>((a, b) => a.ProductId == b.ProductId).ToList();
                // 右連接 RightJoin 內連接 InnerJoin 全連接 FullJoin
    
  • 聯合查詢

                var query1 = db.Query<Product>();
                var query2 = db.Query<Product>();
                db.Union(query1, query2);//聯合
                db.UnionAll(query1, query2);//全聯合
                //執行查詢調用Toxx方法
    
  • 查詢並插入 僅支持同實例的資料庫 跨庫 個人還是建議 用事務分開寫查詢和插入

                    //方式1
                    var result1 = db.Query<Product>().Where(w => w.ProductId == 1489087).Select(s => new
                    {
                        s.ProductCode,
                        s.ProductName
                    }).Insert<Product>(p => new
                    {
                        p.ProductCode,
                        p.ProductName
                    });
    
                    //方式2 需要註意的是 顯示指定不帶 列標識符 例如 `列名稱1` 如有欄位衝突 可自行加上標識符
                    var result2 = db.Query<Product>().Where(w => w.ProductId == 1489087).Select(s => new
                    {
                        s.ProductCode,
                        s.ProductName
                    }).Insert("表名稱 同實例不同庫 可以使用 db.資料庫名稱.表名稱 ", "列名稱1", "列名稱2", "`帶標識的列名稱3`");
    
                    //方式3 需要註意同方式2 一樣
                    var result3 = db.Query<Product>().Where(w => w.ProductId == 1489087).Select(s => new
                    {
                        s.ProductCode,
                        s.ProductName
                    }).Insert("表名稱 同實例不同庫 可以使用 db.資料庫名稱.表名稱 ", new List<string>() { "列名稱1" });
    
  • In查詢

                    // 方式1
                    var data1 = db.Query<Product>().Where(w => SqlFunc.In(w.ProductCode, "1001", "1002")).ToList();
    
                    // 方式2
                    var data2 = db.Query<Product>().Where(w => SqlFunc.In(w.ProductCode, new List<string>() { "123", "456" })).ToList();
    
                    // 方式3 需要動態更新IN值 使用這種
                    var list = new List<string>() { "123", "456" };
                    var data3 = db.Query<Product>().Where(w => SqlFunc.In(w.ProductCode, list)).ToList();
    
                    // 方法4 參數同上一樣 單獨分離IN和NotIN 是為了相容匿名查詢
                    var data4 = db.Query<Product>().In("欄位名稱", "1001", "1002").ToList();
    
  • Select子查詢

                    var subQuery = db.Query<Product>().Where(w => w.ProductId == 1).Select(s => s.ProductName);
                    var sql1 = db.Query<Product>().Select(s => new Product()
                    {
                        Custom1 = db.SubQuery<string>(subQuery)// SubQuery 的泛型是根據你左邊賦值的屬性類型來定義
                    }).ToList();
                    // 這種沒有使用new 的 泛型可隨意定義 實際作用就是避免 對象屬性賦值類型衝突的問題
                    var sql2 = db.Query<Product>().Select(s => db.SubQuery<string>(subQuery)).ToList();
    
  • From子查詢

                    var subQuery = db.Query<Product>();
                    var data = db.Query(subQuery).OrderBy(o => o.ProductCode).ToList();
    
  • Join子查詢

                    var subQuery = db.Query<Product>();
                    var data = db.Query<Product>().InnerJoin(subQuery, (a, b) => a.ProductId == b.ProductId).ToList();
    
  • Include查詢

                    // 聯表條件 預設優先匹配主鍵 其次帶有ID結尾的名稱
                    var data = db.Query<Category>().Include(i => i.Products).ToList();
    
八、Lambda表達式
  • 動態表達式 命名空間 Fast.Framework.Utils

                    var ex = DynamicWhereExp.Create<Product>().AndIF(1 == 1, a => a.DeleteMark == true).Build();
                    var data = db.Query<Product>().Where(ex).ToList();
    
  • Sql函數 自定義函數 需引入命名空間 Fast.Framework.Utils

    • SqlServer

      • 類型轉換

        方法名稱 解析示例值 說明 自定義函數
        ToString CONVERT( VARCHAR(255),123) 轉換 VARCHAR
        ToDateTime CONVERT( DATETIME,‘2022-09-16’) 轉換 DATETIME
        ToDecimal CONVERT( DECIMAL(10,6),‘123’) 轉換 DECIMAL
        ToDouble CONVERT( NUMERIC(10,6),‘123’) 轉換 NUMERIC
        ToSingle CONVERT( FLOAT,‘123’) 轉換 FLOAT
        ToInt32 CONVERT( INT,‘123’) 轉換 INT
        ToInt64 CONVERT( BIGINT,‘123’) 轉換 BIGINT
        ToBoolean CONVERT( BIT,‘1’) 轉換 BIT
        ToChar CONVERT( CHAR(2),'x') 轉換 CHAR
      • 聚合函數

        方法名稱 解析示例值 說明 自定義函數
        Max MAX( a.[xx] ) 最大值
        Min MIN( a.[xx] ) 最小值
        Count COUNT( a.[xx] ) 計數
        Sum SUM( a.[xx] ) 合計
        Avg AVG( a.[xx] ) 平均
      • 數學函數

        方法名稱 解析示例值 說明 自定義函數
        Abs ABS( a.[xx] ) 絕對值
        Round ROUND( a.[xx] ,2 ) 四捨五入
      • 字元串函數

        方法名稱 解析示例值 說明 自定義函數
        StartsWith LIKE ‘%’+'xx' 左模糊
        EndsWith LIKE 'xx'+‘%’ 右模糊
        Contains LIKE ‘%’+'xx'+‘%’ 全模糊
        SubString SUBSTRING( 'xxxxxx' ,1,3) 截取
        Replace REPLACE( 'xxx','x','y') 替換
        Len LEN( 'xxx' ) 長度
        TrimStart LTRIM( ' xx ' ) 修剪起始空格
        TrimEnd RTRIM( ' xx ' ) 修剪末尾空格
        ToUpper UPPER( 'xx' ) 大寫
        ToLower LOWER( 'xx' ) 小寫
        Operation CreateTime >= @Now_1 日期、數值、字元串範圍比較
      • 日期函數

        方法名稱 解析示例值 說明 自定義函數
        DateDiff DATEDIFF( DAY ,a.[xx],b.[xx]) 日期相差
        AddYears DATEADD( YEAR,a.[xx],1 ) 添加年份
        AddMonths DATEADD( MONTH,a.[xx],1 ) 添加月份
        AddDays DATEADD( DAY,a.[xx],1 ) 添加天數
        AddHours DATEADD( HOUR,a.[xx],1 ) 添加時
        AddMinutes DATEADD( MINUTE,a.[xx],1 ) 添加分
        AddSeconds DATEADD( SECOND,a.[xx],1 ) 添加秒
        AddMilliseconds DATEADD( MILLISECOND,a.[xx],1 ) 添加毫秒
        Year YEAR( a.[xx] ) 獲取年份
        Month MONTH( a.[xx] ) 獲取月份
        Day DAY( a.[xx] ) 獲取天數
      • 查詢函數

        方法名稱 解析示例值 說明 自定義函數
        In IN ( a.[xx] ,'x1','x2','x3') In查詢
        NotIn NOT IN ( a.[xx] ,'x1','x2','x3') Not In查詢
      • 其它函數

        方法名稱 解析示例值 說明 自定義函數
        NewGuid NEWID() 獲取GUID
        Equals p.[ProductCode] = '123' 比較
        IsNull ISNULL(a.[xx],0) 是否為空
        Case CASE case
        When WHEN when
        Then THEN then
        Else ELSE else
        End END end
    • MySql

      • 類型轉換

        方法名稱 解析示例值 說明 自定義函數
        ToString CAST( a.`xx` AS CHAR(510) ) 轉換 CHAR(510)
        ToDateTime CAST( a.`xx` AS DATETIME ) 轉換 DATETIME
        ToDecimal CAST( a.`xx` AS DECIMAL(10,6) ) 轉換 DECIMAL(10,6)
        ToDouble CAST( a.`xx` AS DECIMAL(10,6) ) 轉換 DECIMAL(10,6)
        ToInt32 CAST( a.`xx` AS DECIMAL(10) ) 轉換 DECIMAL(10)
        ToInt64 CAST( a.`xx` AS DECIMAL(19) ) 轉換 DECIMAL(19)
        ToBoolean CAST( a.`xx` AS UNSIGNED ) 轉換 UNSIGNED
        ToChar CAST( a.`xx` AS CHAR(2) ) 轉換 CHAR(2)
      • 聚合函數

        方法名稱 解析示例值 說明 自定義函數
        Max MAX( a.`xx` ) 最大值
        Min MIN( a.`xx` ) 最小值
        Count COUNT( a.`xx` ) 計數
        Sum SUM( a.`xx` ) 合計
        Avg AVG( a.`xx` ) 平均
      • 數學函數

        方法名稱 解析示例值 說明 自定義函數
        Abs ABS( a.`xx` ) 絕對值
        Round ROUND( a.`xx` ,2 ) 四捨五入
      • 字元串函數

        方法名稱 解析示例值 說明 自定義函數
        StartsWith LIKE CONCAT( '%','xx' ) 左模糊
        EndsWith LIKE CONCAT( xx','%' ) 右模糊
        Contains LIKE CONCAT( '%','xx','%' ) 全模糊
        SubString SUBSTRING( 'xxxxxx' ,1,3 ) 截取
        Replace REPLACE( 'xxx','x','y' ) 替換
        Len LEN( 'xxx' ) 長度
        Trim TRIM( ' xx ' ) 修剪空格
        TrimStart LTRIM( ' xx ' ) 修剪起始空格
        TrimEnd RTRIM( ' xx ' ) 修剪末尾空格
        ToUpper UPPER( 'xx' ) 大寫
        ToLower LOWER( 'xx' ) 小寫
        Concat CONCAT(a.`xx1`,a.`xx2`) 字元串拼接
      • 日期函數

        方法名稱 解析示例值 說明 自定義函數
        DateDiff DATEDIFF( a.`xx`,b.`xx` ) 日期相差 返回相差天數
        TimestampDiff TIMESTAMPDIFF( DAY,a.`xx`,b.`xx` ) 日期相差 指定時間單位
        AddYears DATE_ADD( a.`xx`,INTERVAL 1 YEAR ) 添加年份
        AddMonths DATE_ADD( a.`xx`,INTERVAL 1 MONTH ) 添加月份
        AddDays DATE_ADD( a.`xx`,INTERVAL 1 DAY ) 添加天數
        AddHours DATE_ADD( a.`xx`,INTERVAL 1 HOUR ) 添加時
        AddMinutes DATE_ADD( a.`xx`,INTERVAL 1 MINUTE ) 添加分
        AddSeconds DATE_ADD( a.`xx`,INTERVAL 1 SECOND ) 添加秒
        AddMilliseconds DATE_ADD( a.`xx`,INTERVAL 1 MINUTE_SECOND ) 添加毫秒
        Year YEAR( a.`xx` ) 獲取年份
        Month MONTH( a.`xx` ) 獲取月份
        Day DAY( a.`xx` ) 獲取天數
      • 查詢函數

        方法名稱 解析示例值 說明 自定義函數
        In IN ( a.`xx` ,'x1','x2','x3' ) In查詢
        NotIn NOT IN ( a.`xx` ,'x1','x2','x3' ) Not In查詢
      • 其它函數

        方法名稱 解析示例值 說明 自定義函數
        NewGuid UUID() 獲取GUID
        Equals p.`ProductCode` = '123' 比較
        IfNull IFNULL( a.`xx`,0 ) 如果為空
        Case CASE case
        When WHEN when
        Then THEN then
        Else ELSE else
        End END end
    • Oracle

      • 類型轉換

        方法名稱 解析示例值 說明 自定義函數
        ToString CAST( a."xx" AS VARCHAR(255) ) 轉換 VARCHAR
        ToDateTime TO_TIMESTAMP( a."xx" ,'yyyy-MM-dd hh:mi:ss.ff') 轉換 DATETIME
        ToDecimal CAST( a."xx" AS DECIMAL(10,6) ) 轉換 DECIMAL
        ToDouble CAST( a."xx" AS NUMBER ) 轉換 NUMBER
        ToSingle CAST( a."xx" AS FLOAT ) 轉換 FLOAT
        ToInt32 CAST( a."xx" AS INT ) 轉換 INT
        ToInt64 CAST( a."xx" AS NUMBER ) 轉換 NUMBER
        ToBoolean CAST( a."xx" AS CHAR(1) ) 轉換 CHAR
        ToChar CAST( a."xx" AS CHAR(2) ) 轉換 CHAR
      • 聚合函數

        方法名稱 解析示例值 說明 自定義函數
        Max MAX( a."xx" ) 最大值
        Min MIN( a."xx" ) 最小值
        Count COUNT( a."xx" ) 計數
        Sum SUM( a."xx" ) 合計
        Avg AVG( a."xx" ) 平均
      • 數學函數

        方法名稱 解析示例值 說明 自定義函數
        Abs ABS( a."xx" ) 絕對值
        Round ROUND( a."xx" ,2 ) 四捨五入
      • 字元串函數

        方法名稱 解析示例值 說明 自定義函數
        StartsWith LIKE CONCAT( '%','xx' ) 左模糊
        EndsWith LIKE CONCAT( 'xx','%' ) 右模糊
        Contains LIKE CONCAT( '%','xx','%' ) 全模糊
        SubString SUBSTRING( 'xxxxxx' ,1,3) 截取
        Replace REPLACE( 'xxx','x','y') 替換
        Length LENGTH( 'xxx' ) 長度
        TrimStart LTRIM( ' xx ' ) 修剪起始空格
        TrimEnd RTRIM( ' xx ' ) 修剪末尾空格
        ToUpper UPPER( 'xx' ) 大寫
        ToLower LOWER( 'xx' ) 小寫
        Concat CONCAT(a."xx1",a."xx2") 字元串拼接
      • 日期函數

        方法名稱 解析示例值 說明 自定義函數
        Year EXTRACT( YEAR FROM a."xx" ) 獲取年份
        Month EXTRACT( MONTH FROM a."xx" ) 獲取月份
        Day EXTRACT( DAY FROM a."xx" ) 獲取天數
      • 查詢函數

        方法名稱 解析示例值 說明 自定義函數
        In IN ( a."xx" ,'x1','x2','x3') In查詢
        NotIn NOT IN ( a."xx",'x1','x2','x3') Not In查詢
      • 其它函數

        方法名稱 解析示例值 說明 自定義函數
        Equals p."ProductCode" = '123' 比較
        Nvl NVL( a."xx",0 ) 空,預設
        Case CASE case
        When WHEN when
        Then THEN then
        Else ELSE else
        End END end
    • PostgreSql

      • 類型轉換

        方法名稱 解析示例值 說明 自定義函數
        ToString a."xx"::VARCHAR(255) 轉換 VARCHAR
        ToDateTime a."xx"::TIMESTAMP 轉換 TIMESTAMP
        ToDecimal a."xx"::DECIMAL(10,6) 轉換 DECIMAL
        ToDouble a."xx"::NUMERIC(10,6) 轉換 NUMERIC
        ToSingle a."xx"::REAL 轉換 REAL
        ToInt32 a."xx"::INTEGER 轉換 INT
        ToInt64 a."xx"::BIGINT 轉換 BIGINT
        ToBoolean a."xx"::BOOLEAN 轉換 BOOLEAN
        ToChar a."xx"::CHAR(2) 轉換 CHAR
      • 聚合函數

        方法名稱 解析示例值 說明 自定義函數
        Max MAX( a."xx" ) 最大值
        Min MIN( a."xx" ) 最小值
        Count COUNT( a."xx" ) 計數
        Sum SUM( a."xx" ) 合計
        Avg AVG( a."xx" ) 平均
      • 數學函數

        方法名稱 解析示例值 說明 自定義函數
        Abs ABS( a."xx" ) 絕對值
        Round ROUND( a."xx" ,2 ) 四捨五入
      • 字元串函數

        方法名稱 解析示例值 說明 自定義函數
        StartsWith LIKE CONCAT( '%','xx' ) 左模糊
        EndsWith LIKE CONCAT( 'xx','%' ) 右模糊
        Contains LIKE CONCAT( '%','xx','%' ) 全模糊
        SubString SUBSTRING( 'xxxxxx' ,1,3 ) 截取
        Replace REPLACE( 'xxx','x','y' ) 替換
        Length LENGTH( 'xxx' ) 長度
        Trim TRIM( ' xx ' ) 修剪空格
        TrimStart LTRIM( ' xx ' ) 修剪起始空格
        TrimEnd RTRIM( ' xx ' ) 修剪末尾空格
        ToUpper UPPER( 'xx' ) 大寫
        ToLower LOWER( 'xx' ) 小寫
        Concat CONCAT(a."xx1",a."xx2") 字元串拼接
      • 日期函數

        方法名稱 解析示例值 說明 自定義函數
        AddYears a."xx" + INTERVAL '1 YEAR' 添加年份
        AddMonths a."xx" + INTERVAL '1 MONTH' 添加月份
        AddDays a."xx" + INTERVAL '1 DAY' 添加天數
        AddHours a."xx" + INTERVAL '1 HOUR' 添加時
        AddMinutes a."xx" + INTERVAL '1 MINUTE' 添加分
        AddSeconds a."xx" + INTERVAL '1 SECOND' 添加秒
        AddMilliseconds a."xx" + INTERVAL '1 MINUTE_SECOND' 添加毫秒
        Year YEAR( a."xx" ) 獲取年份
        Month MONTH( a."xx" ) 獲取月份
        Day DAY( a."xx" ) 獲取天數
      • 查詢函數

        方法名稱 解析示例值 說明 自定義函數
        In
        您的分享是我們最大的動力!

        -Advertisement-
        Play Games
        更多相關文章
        • Midjourney,是一個革命性的基於人工智慧的藝術生成器,可以從被稱為提示的簡單文本描述中生成令人驚嘆的圖像。Midjourney已經迅速成為藝術家、設計師和營銷人員的首選工具(包括像我這樣根本不會設計任何東西的無能之輩)。 為了幫助你開始使用這個強大的工具,我們彙編了一份15個資源的清單,可以 ...
        • template<typename T = CString, typename _Data = CString> struct Union_node//!< 節點 { Union_node() :nColor(0) {} std::vector<Union_node*> vecNodeSon; T ...
        • Python基礎—conda使用筆記 1. 環境配置 由於用conda管理虛擬環境真滴很方便,所以主要使用conda,就不單獨去裝Python了。 1.1. Miniconda3安裝 Miniconda3官網下載地址:Miniconda Miniconda3清華鏡像下載:清華鏡像-Miniconda ...
        • 在B站自學Python 站主:Python_子木 授課:楊淑娟 平臺: 馬士兵教育 python: 3.9.9 #python打包exe文件 #安裝PyInstaller pip install PyInstaller #-F打包exe文件,stusystem\stusystem.py到py的路徑, ...
        • 1.更改代理(方便步驟3) 方法一: go env -w GOPROXY="https://goproxy.cn" 方法二:(非永久性,該方法對我有效) $env:GOPROXY="https://goproxy.cn" 註: http://mirrors.aliyun.com/goproxy/ 阿 ...
        • 圖像梯度圖像梯度計算的是圖像變化的速度 對於圖像的邊緣部分,其灰度值變化較大,梯度值也較大相反,對於圖像中比較平滑的部分,其灰度值變化較小,相應的梯度值也較小。圖像梯度計算需要求導數,但是圖像梯度一般通過計算像素值的差來得到梯度的近似值(近似導數值)。(差分,離散) Sobel運算元 1 #Sobel ...
        • 模式匹配 模式 模式是Rust中的一種特殊語法,用於匹配複雜和簡單類型的結構 將模式與匹配表達式和其他構造結合使用,可以更好地控製程序的控制流 模式由以下元素(的一些組合)組成: 字面值 解構的數組、enum、struct 和 tuple 變數 通配符 占位符 想要使用模式,需要將其與某個值進行比較 ...
        • 頂級語句 將類和類裡面Main函數省略,只留下核心的邏輯代碼就是頂級語句! 1.頂級語句1 await System.Threading.Tasks.Task.Delay(1000); System.Console.WriteLine("Hi!"); return 0; static class $ ...
        一周排行
          -Advertisement-
          Play Games
        • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
        • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
        • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
        • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
        • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
        • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
        • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
        • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
        • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
        • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...