【轉載】微軟官方提供的Sqlserver資料庫操作幫助類SQLHelper類

来源:https://www.cnblogs.com/xu-yi/archive/2019/03/13/10525019.html
-Advertisement-
Play Games

在.NET平臺中,C#語言一般使用ADO.NET組件來操作Sqlserver資料庫,通過ADO.NET組件可以實現連接資料庫、查詢數據集、執行SQL語句以及關閉資料庫連接等操作,為此網上有很多開發者自定義封裝好的SqlHelper類供使用,其實微軟官方自己也提供了一個比較完整的Sqlserver數據 ...


在.NET平臺中,C#語言一般使用ADO.NET組件來操作Sqlserver資料庫,通過ADO.NET組件可以實現連接資料庫、查詢數據集、執行SQL語句以及關閉資料庫連接等操作,為此網上有很多開發者自定義封裝好的SqlHelper類供使用,其實微軟官方自己也提供了一個比較完整的Sqlserver資料庫操作幫助類SqlHelper,該幫助類文件中包含了詳細的中文註釋。

該SqlHelper類比較完整,代碼量比較多,因此博主加了個鏈接提供個讀者下載,百度網盤下載地址:SqlHelper類

備註:此文章轉載自微軟官方提供的Sqlserver資料庫操作幫助類SQLHelper類_IT技術小趣屋

具體微軟官方幫助類實現如下:

using System;
using System.Data;
using System.Xml;
using System.Data.SqlClient;
using System.Collections;
namespace Book.DAL
{
    /// <summary>
    /// SqlServer數據訪問幫助類
    /// </summary>
    public sealed class SqlHelper
    {
        #region 私有構造函數和方法
        private SqlHelper() {}
        /// <summary>
        /// 將SqlParameter參數數組(參數值)分配給SqlCommand命令.
        /// 這個方法將給任何一個參數分配DBNull.Value;
        /// 該操作將阻止預設值的使用.
        /// </summary>
        /// <param>命令名</param>
        /// <param>SqlParameters數組</param>
        private static void AttachParameters(SqlCommand command, SqlParameter[] commandParameters)
        {
            if( command == null ) throw new ArgumentNullException( "command" );
            if( commandParameters != null )
            {
                foreach (SqlParameter p in commandParameters)
                {
                    if( p != null )
                    {
                        // 檢查未分配值的輸出參數,將其分配以DBNull.Value.
                        if ( ( p.Direction == ParameterDirection.InputOutput || p.Direction == ParameterDirection.Input ) && 
                            (p.Value == null))
                        {
                            p.Value = DBNull.Value;
                        }
                        command.Parameters.Add(p);
                    }
                }
            }
        }
        
        /// <summary>
        /// 將DataRow類型的列值分配到SqlParameter參數數組.
        /// </summary>
        /// <param>要分配值的SqlParameter參數數組</param>
        /// <param>將要分配給存儲過程參數的DataRow</param>
        private static void AssignParameterValues(SqlParameter[] commandParameters, DataRow dataRow)
        {
            if ((commandParameters == null) || (dataRow == null)) 
            {
                return;
            }
            int i = 0;
            // 設置參數值
            foreach(SqlParameter commandParameter in commandParameters)
            {
                // 創建參數名稱,如果不存在,只拋出一個異常.
                if( commandParameter.ParameterName == null || 
                    commandParameter.ParameterName.Length <= 1 )
                    throw new Exception( 
                        string.Format("請提供參數{0}一個有效的名稱{1}.", i, commandParameter.ParameterName ) );
                // 從dataRow的表中獲取為參數數組中數組名稱的列的索引.
                // 如果存在和參數名稱相同的列,則將列值賦給當前名稱的參數.
                if (dataRow.Table.Columns.IndexOf(commandParameter.ParameterName.Substring(1)) != -1)
                    commandParameter.Value = dataRow[commandParameter.ParameterName.Substring(1)];
                i++;
            }
        }
        
        /// <summary>
        /// 將一個對象數組分配給SqlParameter參數數組.
        /// </summary>
        /// <param>要分配值的SqlParameter參數數組</param>
        /// <param>將要分配給存儲過程參數的對象數組</param>
        private static void AssignParameterValues(SqlParameter[] commandParameters, object[] parameterValues)
        {
            if ((commandParameters == null) || (parameterValues == null)) 
            {
                return;
            }
            // 確保對象數組個數與參數個數匹配,如果不匹配,拋出一個異常.
            if (commandParameters.Length != parameterValues.Length)
            {
                throw new ArgumentException("參數值個數與參數不匹配.");
            }
            // 給參數賦值
            for (int i = 0, j = commandParameters.Length; i < j; i++)
            {
                // If the current array value derives from IDbDataParameter, then assign its Value property
                if (parameterValues[i] is IDbDataParameter)
                {
                    IDbDataParameter paramInstance = (IDbDataParameter)parameterValues[i];
                    if( paramInstance.Value == null )
                    {
                        commandParameters[i].Value = DBNull.Value; 
                    }
                    else
                    {
                        commandParameters[i].Value = paramInstance.Value;
                    }
                }
                else if (parameterValues[i] == null)
                {
                    commandParameters[i].Value = DBNull.Value;
                }
                else
                {
                    commandParameters[i].Value = parameterValues[i];
                }
            }
        }
        
        /// <summary>
        /// 預處理用戶提供的命令,資料庫連接/事務/命令類型/參數
        /// </summary>
        /// <param>要處理的SqlCommand</param>
        /// <param>資料庫連接</param>
        /// <param>一個有效的事務或者是null值</param>
        /// <param>命令類型 (存儲過程,命令文本, 其它.)</param>
        /// <param>存儲過程名或都T-SQL命令文本</param>
        /// <param>和命令相關聯的SqlParameter參數數組,如果沒有參數為'null'</param>
        /// <param><c>true</c> 如果連接是打開的,則為true,其它情況下為false.</param>
        private static void PrepareCommand(SqlCommand command, SqlConnection connection, SqlTransaction transaction, CommandType commandType, string commandText, SqlParameter[] commandParameters, out bool mustCloseConnection )
        {
            if( command == null ) throw new ArgumentNullException( "command" );
            if( commandText == null || commandText.Length == 0 ) throw new ArgumentNullException( "commandText" );
            // If the provided connection is not open, we will open it
            if (connection.State != ConnectionState.Open)
            {
                mustCloseConnection = true;
                connection.Open();
            }
            else
            {
                mustCloseConnection = false;
            }
            // 給命令分配一個資料庫連接.
            command.Connection = connection;
            // 設置命令文本(存儲過程名或SQL語句)
            command.CommandText = commandText;
            // 分配事務
            if (transaction != null)
            {
                if( transaction.Connection == null ) throw new ArgumentException( "The transaction was rollbacked or commited, please provide an open transaction.", "transaction" );
                command.Transaction = transaction;
            }
            // 設置命令類型.
            command.CommandType = commandType;
            // 分配命令參數
            if (commandParameters != null)
            {
                AttachParameters(command, commandParameters);
            }
            return;
        }
        #endregion 私有構造函數和方法結束
            
        #region ExecuteNonQuery命令
        /// <summary>
        /// 執行指定連接字元串,類型的SqlCommand.
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders");
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串</param>
        /// <param>命令類型 (存儲過程,命令文本, 其它.)</param>
        /// <param>存儲過程名稱或SQL語句</param>
        /// <returns>返回命令影響的行數</returns>
        public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText)
        {
            return ExecuteNonQuery(connectionString, commandType, commandText, (SqlParameter[])null);
        }
        
        /// <summary>
        /// 執行指定連接字元串,類型的SqlCommand.如果沒有提供參數,不返回結果.
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24));
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串</param>
        /// <param>命令類型 (存儲過程,命令文本, 其它.)</param>
        /// <param>存儲過程名稱或SQL語句</param>
        /// <param>SqlParameter參數數組</param>
        /// <returns>返回命令影響的行數</returns>
        public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
        {
            if( connectionString == null || connectionString.Length == 0 ) throw new ArgumentNullException( "connectionString" );
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                return ExecuteNonQuery(connection, commandType, commandText, commandParameters);
            }
        }
        
        /// <summary>
        /// 執行指定連接字元串的存儲過程,將對象數組的值賦給存儲過程參數,
        /// 此方法需要在參數緩存方法中探索參數並生成參數.
        /// </summary>
        /// <remarks>
        /// 這個方法沒有提供訪問輸出參數和返回值.
        /// 示例:  
        ///  int result = ExecuteNonQuery(connString, "PublishOrders", 24, 36);
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串/param>
        /// <param>存儲過程名稱</param>
        /// <param>分配到存儲過程輸入參數的對象數組</param>
        /// <returns>返回受影響的行數</returns>
        public static int ExecuteNonQuery(string connectionString, string spName, params object[] parameterValues)
        {
            if( connectionString == null || connectionString.Length == 0 ) throw new ArgumentNullException( "connectionString" );
            if( spName == null || spName.Length == 0 ) throw new ArgumentNullException( "spName" );
            // 如果存在參數值
            if ((parameterValues != null) && (parameterValues.Length > 0)) 
            {
                // 從探索存儲過程參數(載入到緩存)並分配給存儲過程參數數組.
                SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);
                // 給存儲過程參數賦值
                AssignParameterValues(commandParameters, parameterValues);
                return ExecuteNonQuery(connectionString, CommandType.StoredProcedure, spName, commandParameters);
            }
            else 
            {
                // 沒有參數情況下
                return ExecuteNonQuery(connectionString, CommandType.StoredProcedure, spName);
            }
        }
        
        /// <summary>
        /// 執行指定資料庫連接對象的命令 
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders");
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>命令類型(存儲過程,命令文本或其它.)</param>
        /// <param>存儲過程名稱或T-SQL語句</param>
        /// <returns>返回影響的行數</returns>
        public static int ExecuteNonQuery(SqlConnection connection, CommandType commandType, string commandText)
        {
            return ExecuteNonQuery(connection, commandType, commandText, (SqlParameter[])null);
        }
        
        /// <summary>
        /// 執行指定資料庫連接對象的命令
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24));
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>命令類型(存儲過程,命令文本或其它.)</param>
        /// <param>T存儲過程名稱或T-SQL語句</param>
        /// <param>SqlParamter參數數組</param>
        /// <returns>返回影響的行數</returns>
        public static int ExecuteNonQuery(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
        {    
            if( connection == null ) throw new ArgumentNullException( "connection" );
            // 創建SqlCommand命令,併進行預處理
            SqlCommand cmd = new SqlCommand();
            bool mustCloseConnection = false;
            PrepareCommand(cmd, connection, (SqlTransaction)null, commandType, commandText, commandParameters, out mustCloseConnection );
            
            // Finally, execute the command
            int retval = cmd.ExecuteNonQuery();
            
            // 清除參數,以便再次使用.
            cmd.Parameters.Clear();
            if( mustCloseConnection )
                connection.Close();
            return retval;
        }
        
        /// <summary>
        /// 執行指定資料庫連接對象的命令,將對象數組的值賦給存儲過程參數.
        /// </summary>
        /// <remarks>
        /// 此方法不提供訪問存儲過程輸出參數和返回值
        /// 示例:  
        ///  int result = ExecuteNonQuery(conn, "PublishOrders", 24, 36);
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>存儲過程名</param>
        /// <param>分配給存儲過程輸入參數的對象數組</param>
        /// <returns>返回影響的行數</returns>
        public static int ExecuteNonQuery(SqlConnection connection, string spName, params object[] parameterValues)
        {
            if( connection == null ) throw new ArgumentNullException( "connection" );
            if( spName == null || spName.Length == 0 ) throw new ArgumentNullException( "spName" );
            // 如果有參數值
            if ((parameterValues != null) && (parameterValues.Length > 0)) 
            {
                // 從緩存中載入存儲過程參數
                SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connection, spName);
                // 給存儲過程分配參數值
                AssignParameterValues(commandParameters, parameterValues);
                return ExecuteNonQuery(connection, CommandType.StoredProcedure, spName, commandParameters);
            }
            else 
            {
                return ExecuteNonQuery(connection, CommandType.StoredProcedure, spName);
            }
        }
        
        /// <summary>
        /// 執行帶事務的SqlCommand.
        /// </summary>
        /// <remarks>
        /// 示例.:  
        ///  int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "PublishOrders");
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>命令類型(存儲過程,命令文本或其它.)</param>
        /// <param>存儲過程名稱或T-SQL語句</param>
        /// <returns>返回影響的行數/returns>
        public static int ExecuteNonQuery(SqlTransaction transaction, CommandType commandType, string commandText)
        {
            return ExecuteNonQuery(transaction, commandType, commandText, (SqlParameter[])null);
        }
        
        /// <summary>
        /// 執行帶事務的SqlCommand(指定參數).
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>命令類型(存儲過程,命令文本或其它.)</param>
        /// <param>存儲過程名稱或T-SQL語句</param>
        /// <param>SqlParamter參數數組</param>
        /// <returns>返回影響的行數</returns>
        public static int ExecuteNonQuery(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
        {
            if( transaction == null ) throw new ArgumentNullException( "transaction" );
            if( transaction != null && transaction.Connection == null ) throw new ArgumentException( "The transaction was rollbacked or commited, please provide an open transaction.", "transaction" );
            // 預處理
            SqlCommand cmd = new SqlCommand();
            bool mustCloseConnection = false;
            PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters, out mustCloseConnection );
                
            // 執行
            int retval = cmd.ExecuteNonQuery();
                
            // 清除參數集,以便再次使用.
            cmd.Parameters.Clear();
            return retval;
        }
        
        /// <summary>
        /// 執行帶事務的SqlCommand(指定參數值).
        /// </summary>
        /// <remarks>
        /// 此方法不提供訪問存儲過程輸出參數和返回值
        /// 示例:  
        ///  int result = ExecuteNonQuery(conn, trans, "PublishOrders", 24, 36);
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>存儲過程名</param>
        /// <param>分配給存儲過程輸入參數的對象數組</param>
        /// <returns>返回受影響的行數</returns>
        public static int ExecuteNonQuery(SqlTransaction transaction, string spName, params object[] parameterValues)
        {
            if( transaction == null ) throw new ArgumentNullException( "transaction" );
            if( transaction != null && transaction.Connection == null ) throw new ArgumentException( "The transaction was rollbacked or commited, please provide an open transaction.", "transaction" );
            if( spName == null || spName.Length == 0 ) throw new ArgumentNullException( "spName" );
            // 如果有參數值
            if ((parameterValues != null) && (parameterValues.Length > 0)) 
            {
                // 從緩存中載入存儲過程參數,如果緩存中不存在則從資料庫中檢索參數信息並載入到緩存中. ()
                SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(transaction.Connection, spName);
                // 給存儲過程參數賦值
                AssignParameterValues(commandParameters, parameterValues);
                // 調用重載方法
                return ExecuteNonQuery(transaction, CommandType.StoredProcedure, spName, commandParameters);
            }
            else 
            {
                // 沒有參數值
                return ExecuteNonQuery(transaction, CommandType.StoredProcedure, spName);
            }
        }
        #endregion ExecuteNonQuery方法結束
            
        #region ExecuteDataset方法
        /// <summary>
        /// 執行指定資料庫連接字元串的命令,返回DataSet.
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  DataSet ds = ExecuteDataset(connString, CommandType.StoredProcedure, "GetOrders");
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串</param>
        /// <param>命令類型 (存儲過程,命令文本或其它)</param>
        /// <param>存儲過程名稱或T-SQL語句</param>
        /// <returns>返回一個包含結果集的DataSet</returns>
        public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText)
        {
            return ExecuteDataset(connectionString, commandType, commandText, (SqlParameter[])null);
        }
        
        /// <summary>
        /// 執行指定資料庫連接字元串的命令,返回DataSet.
        /// </summary>
        /// <remarks>
        /// 示例: 
        ///  DataSet ds = ExecuteDataset(connString, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串</param>
        /// <param>命令類型 (存儲過程,命令文本或其它)</param>
        /// <param>存儲過程名稱或T-SQL語句</param>
        /// <param>SqlParamters參數數組</param>
        /// <returns>返回一個包含結果集的DataSet</returns>
        public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
        {
            if( connectionString == null || connectionString.Length == 0 ) throw new ArgumentNullException( "connectionString" );
            // 創建並打開資料庫連接對象,操作完成釋放對象.
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                // 調用指定資料庫連接字元串重載方法.
                return ExecuteDataset(connection, commandType, commandText, commandParameters);
            }
        }
        
        /// <summary>
        /// 執行指定資料庫連接字元串的命令,直接提供參數值,返回DataSet.
        /// </summary>
        /// <remarks>
        /// 此方法不提供訪問存儲過程輸出參數和返回值.
        /// 示例: 
        ///  DataSet ds = ExecuteDataset(connString, "GetOrders", 24, 36);
        /// </remarks>
        /// <param>一個有效的資料庫連接字元串</param>
        /// <param>存儲過程名</param>
        /// <param>分配給存儲過程輸入參數的對象數組</param>
        /// <returns>返回一個包含結果集的DataSet</returns>
        public static DataSet ExecuteDataset(string connectionString, string spName, params object[] parameterValues)
        {
            if( connectionString == null || connectionString.Length == 0 ) throw new ArgumentNullException( "connectionString" );
            if( spName == null || spName.Length == 0 ) throw new ArgumentNullException( "spName" );
            
            if ((parameterValues != null) && (parameterValues.Length > 0)) 
            {
                // 從緩存中檢索存儲過程參數
                SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);
                // 給存儲過程參數分配值
                AssignParameterValues(commandParameters, parameterValues);
                return ExecuteDataset(connectionString, CommandType.StoredProcedure, spName, commandParameters);
            }
            else 
            {
                return ExecuteDataset(connectionString, CommandType.StoredProcedure, spName);
            }
        }
        
        /// <summary>
        /// 執行指定資料庫連接對象的命令,返回DataSet.
        /// </summary>
        /// <remarks>
        /// 示例:  
        ///  DataSet ds = ExecuteDataset(conn, CommandType.StoredProcedure, "GetOrders");
        /// </remarks>
        /// <param>一個有效的資料庫連接對象</param>
        /// <param>命令類型 (存儲過程,命令文本或其它)</param>
        /// <param>存儲過程名或T-SQL語句</param>
        /// <returns>返回一個包含結果集的DataSet</returns>
        public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText)
        {
            return ExecuteDataset(connection, commandType, commandText, (

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

-Advertisement-
Play Games
更多相關文章
  • 在實際的業務開發中,有時候可能需要用到漢字轉換為對應的拼音的情況。在現實的網路生活中我們有時候也能遇到過這種情況,比如你註冊功能變數名稱或者註冊某個網站賬號的時候,當你輸入中文名字的時候,系統自動將你的漢語拼音作為英文寫法輸出來。因此漢字轉拼音有時候是個剛需業務,下麵封裝了一個漢字轉拼音的實際應用類。 定義 ...
  • 圖片處理是C#程式開發中時常會涉及到的一個業務,除了圖像的上傳、保存以及下載等功能外,根據上傳的圖片生成一個縮略圖也是常見業務,在C#語言中,可以通過Image類提供的相關方法對圖片進行操作,如指定寬高對圖片進行縮放, 指定高寬裁減裁剪圖片、生成圖片水印等。 定義一個圖片處理工具類PicDeal,該 ...
  • FTP是一個8位的客戶端-伺服器協議,能操作任何類型的文件而不需要進一步處理,就像MIME或Unicode一樣。可以通過C#中的FtpWebRequest類、NetworkCredential類、WebRequestMethods類來實現一個FTP操作的相關輔助類FTPHelper。 先來看MSDN ...
  • 今天在IIS中部署ASP.NET網站後,訪問網站報錯,提示信息為:未能載入文件或程式集XXX.dll或它的某一個依賴項,不是有效的Win32應用程式(異常來至HRESULT:0x800700C1)。通過錯誤提示信息進行分析,可知道這個組件為32位操作系統下的組件,而網站環境又是在64位操作系統下的應 ...
  • 將網站發佈後部署到IIS後,配置完應用程式池以及相關設置項後,在瀏覽器中訪問設置好的網站,出現403.14 - Forbidden的錯誤信息,從錯誤信息的提示來看,應該是IIS伺服器此網站目錄的內容被列為禁止訪問,不列出此目錄的內容。解決的辦法是在IIS的“處理程式映射設置”中添加 “腳本映射”。解 ...
  • 使用HttpWebRequest等Http相關類,可以在應用程式中或者網站中模擬瀏覽器發送Post請求,在請求帶入相應的Post參數值,而後請求回遠程網頁信息。實現這一功能也很簡單,主要是依靠HttpWebRequest、HttpWebResponse、Stream等幾個類來完成。 首先來看下MSD ...
  • 半形指的是一個字元占用一個標準字元的位置。全形指一個字元占用兩個標準字元位置的狀態。在C#中,我們可以通過程式的方法,將相應的半形字元串信息轉換為全形類型,也可以實現全形轉半形功能。 相應封裝好的方法如下: 備註:此屋文章轉載自C#中全形轉半形以及半形轉全形_IT技術小趣屋。 ...
  • 預設情況下,瀏覽器端發送Ajax請求一般被禁止跨域訪問,如A功能變數名稱網站訪問B功能變數名稱網站的請求會被終止,在ASP.NET MVC項目中,我們可以配置相應的設置項,允許網站的介面跨域訪問,主要需要設置Access-Control-Allow-Origin、Access-Control-Allow-Heade ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...