using System; using System.Collections; using System.Collections.Generic; using System.Data; using System.Data.SqlClient; using System.IO; using System.Reflection; using System.Runtime.Serialization.Formatters.Binary; using System.Xml; namespace Test_DBUtility { /// <summary> /// 數據庫訪問抽象基類 (基於MS-SQLServer2005或以上版本) /// 此類為抽象類 abstract ,不允許實例化,在應用時直接調用即可 /// Autho :zhouzhilong /// version :1.2 /// LastEditTime:2010-10-09 /// </summary> public abstract class SqlHelper { //數據庫連接字符串(web.config來配置),可以動態更改connectionString支持多數據庫. public static readonly string LocalSqlServer = System.Configuration.ConfigurationManager.AppSettings["ConnectionString"].ToString(); #region ===========通用分頁存儲過程=========== /// <summary> /// 通用分頁存儲過程 /// </summary> /// <param name="connectionString">連接</param> /// <param name="tblName">要顯示的表或多個表的連接</param> /// <param name="strGetFields"> 需要返回的列</param> /// <param name="fldName">排序的字段名</param> /// <param name="PageSize">頁尺寸</param> /// <param name="PageIndex">頁碼</param> /// <param name="doCount">返回記錄總數, 非 0 值則返回</param> /// <param name="OrderType">1降序 ,0 升序,其他 多字段order 條件</param> /// <param name="strWhere">查詢條件 (注意: 不要加 WHERE)</param> /// <returns>查詢當前頁的數據集</returns> public static DataSet PageList(string connectionString, string tblName, string strGetFields, string fldName , int PageSize, int PageIndex, int doCount, int OrderType, string strWhere) { SqlParameter[] parameters ={ new SqlParameter("@tblName",SqlDbType.NVarChar,255), new SqlParameter("@strGetFields",SqlDbType.NVarChar,1000), new SqlParameter("@fldName",SqlDbType.NVarChar,255), new SqlParameter("@PageSize",SqlDbType.Int), new SqlParameter("@PageIndex",SqlDbType.Int), new SqlParameter("@doCount",SqlDbType.Bit), new SqlParameter("@OrderType",SqlDbType.Int), //new SqlParameter("@strWhere",SqlDbType.NVarChar,1500)}; new SqlParameter("@strWhere",SqlDbType.VarChar,8000)}; parameters[0].Value = tblName; parameters[1].Value = (strGetFields == null) ? "*" : strGetFields; parameters[2].Value = (fldName == null) ? "" : fldName; parameters[3].Value = PageSize; parameters[4].Value = PageIndex; parameters[5].Value = doCount; parameters[6].Value = OrderType; parameters[7].Value = (strWhere == null) ? "" : strWhere; DataSet ds = RunProcedureDS(connectionString, "PageList", parameters, "PageListTable"); return ds; } #endregion #region ===========執行簡單SQL語句============ /// <summary> /// 獲取表某個字段的最大值 /// </summary> /// <param name="FieldName"></param> /// <param name="TableName"></param> /// <returns></returns> public static int GetMaxID(string connectionString, string FieldName, string TableName) { string strSql = "select max(" + FieldName + ") from " + TableName; DataSet ds = ExecuteDataSet(connectionString, strSql); if (ds.Tables[0].Rows[0][0] != DBNull.Value) { return int.Parse(ds.Tables[0].Rows[0][0].ToString()); } else { return 0; } } /// <summary> /// 檢測一個記錄是否存在(SqlParameter語句方式) /// </summary> /// <param name="strSql"></param> /// <param name="cmdParms"></param> /// <returns></returns> public static bool ExistsRecord(string connectionString, string strSql, params SqlParameter[] cmdParms) { DataSet ds = RunProcedureDS(connectionString, strSql, cmdParms); return int.Parse(ds.Tables[0].Rows[0][0].ToString()) > 0; } /// <summary> ///執行查詢,並將查詢返回的結果集中第一行的第一列作為 .NET Framework 數據類型返回。忽略額外的列或行。返回查詢結果(object)。 /// </summary> /// <param name="SQLString">計算查詢結果語句</param> /// <returns>查詢結果(object)</returns> public static object GetSingle(string connectionString, string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); object obj = cmd.ExecuteScalar(); if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value))) { return null; } else { return obj; } } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw new Exception(e.Message); } } } } #endregion 執行簡單SQL語句 #region StrSQL執行結果,返回執行后受影響的行數 /*【公告】:ExecuteNonQuery()方法介紹 *對於 UPDATE、INSERT 和 DELETE 語句, *返回值為該命令所影響的行數。對於所有其他類型的語句, *返回值為 -1。如果發生回滾,返回值也為 -1。 */ /// <summary> /// 執行SQL語句,返回影響的記錄數,select類型的語句此方法不可行。 /// 對於select方法應該通過Dataset.Tables[0].Rows.Count來判斷 /// </summary> /// <param name="SQLString">SQL語句</param> /// <returns>影響的記錄數</returns> public static int ExecuteSql(string connectionString, string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException E) { connection.Close(); throw new Exception(E.Message); } } } } /// <summary> /// 方法重載,限定查詢時間,返回影響的記錄數 /// 客觀的多並發查詢時,可限制用戶查詢時間,以免對服務器增加負擔 /// </summary> /// <param name="Times">等待命令執行的時間,默認值為 30 秒。</param> /// <returns>影響的記錄數</returns> public static int ExecuteSql(string connectionString, string SQLstring, int Times) { using (SqlConnection conntion = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLstring, conntion)) { try { conntion.Open(); cmd.CommandTimeout = Times;//默認值為 30 秒 int rows = cmd.ExecuteNonQuery(); return rows; } catch (System.Data.SqlClient.SqlException e) { conntion.Close(); throw e; } } } } /// <summary> /// 執行SQL語句,返回記錄的條數【注意是記錄數】; /// 獲取SQL字段第一行第一字段的數值,請不要用select /// </summary> /// <param name="SQLString">SQL語句</param> /// <returns>影響的記錄數</returns> public static int ExecuteCountSql(string connectionString, string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand(SQLString, connection)) { try { connection.Open(); SqlDataReader dr = cmd.ExecuteReader(); dr.Read(); int count = int.Parse(dr[0].ToString()); return count; } catch (System.Data.SqlClient.SqlException E) { connection.Close(); throw new Exception(E.Message); } } } } /// <summary> /// 執行帶一個存儲過程參數的的SQL語句。 /// </summary> /// <param name="SQLString">SQL語句</param> /// <param name="content">參數內容,比如一個字段是格式復雜的文章,有特殊符號,可以通過這個方式添加</param> /// <returns>影響的記錄數</returns> public static int ExecuteSql(string connectionString, string SQLString, string content) { using (SqlConnection connection = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand(SQLString, connection); SqlParameter myParameter = new SqlParameter("@content", SqlDbType.NText); myParameter.Value = content; cmd.Parameters.Add(myParameter); try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (SqlException E) { throw new Exception(E.Message); } finally { cmd.Dispose(); } } } /// <summary> /// 向數據庫里插入圖像格式的字段(和上面情況類似的另一種實例) /// </summary> /// <param name="strSQL">SQL語句</param> /// <param name="fs">圖像字節,數據庫的字段類型為image的情況</param> /// <returns>影響的記錄數</returns> public static int ExecuteSqlInsertImg(string connectionString, string strSQL, byte[] fs) { using (SqlConnection connection = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand(strSQL, connection); SqlParameter myParameter = new SqlParameter("@fs", SqlDbType.Image); myParameter.Value = fs; cmd.Parameters.Add(myParameter); try { connection.Open(); int rows = cmd.ExecuteNonQuery(); return rows; } catch (SqlException E) { throw new Exception(E.Message); } finally { cmd.Dispose(); } } } /// <summary> /// 執行帶參數的SQL語句,返回影響的記錄數 /// </summary> /// <param name="connectionString">連接字符串</param> /// <param name="SQLString">SQL語句</param> /// <param name="cmdParms">參數</param> /// <returns>影響的記錄數</returns> public static int ExecuteSql(string connectionString, string SQLString, params SqlParameter[] cmdParms) { using (SqlConnection connection = new SqlConnection(connectionString)) { using (SqlCommand cmd = new SqlCommand()) { try { PrepareCommand(cmd, connection, null, SQLString, cmdParms); int rows = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return rows; } catch (System.Data.SqlClient.SqlException E) { connection.Close(); throw new Exception(E.Message); } } } } /// <summary> /// 執行存儲過程,返回Return值【這個方法還沒看明白,- - 】 /// </summary> /// <param name="storedProcName">存儲過程名</param> /// <param name="parameters">存儲過程參數</param> /// <param name="rowsAffected">影響的行數</param> /// <returns></returns> public static int RunProcedure(string connectionString, string storedProcName, IDataParameter[] parameters, out int rowsAffected) { using (SqlConnection connection = new SqlConnection(connectionString)) { int result; connection.Open(); SqlCommand command = BuildIntCommand(connection, storedProcName, parameters); rowsAffected = command.ExecuteNonQuery(); result = (int)command.Parameters["ReturnValue"].Value; connection.Close(); return result; } } #endregion #region ============獲取DataReader============ /*【公告】下面的方法調用(先實例化一個dr)該方法后, * 一定要對SqlDataReader進行Close (對實例化的dr進行 dr.Close(); * 如果不Close掉,則會保持read回話狀態,加重數據庫負荷) */ /// <summary> /// 執行查詢語句,返回SqlDataReader /// </summary> /// <param name="strSQL">查詢語句</param> /// <returns>SqlDataReader</returns> public static SqlDataReader ExecuteReader(string connectionString, string strSQL) { SqlConnection connection = new SqlConnection(connectionString); SqlCommand cmd = new SqlCommand(strSQL, connection); try { connection.Open(); SqlDataReader myReader = cmd.ExecuteReader(); return myReader; } catch (System.Data.SqlClient.SqlException e) { throw new Exception(e.Message); } finally { connection.Close(); } } /// <summary> /// 執行存儲過程,返回SqlDataReader /// </summary> /// <param name="storedProcName">存儲過程名</param> /// <param name="parameters">存儲過程參數</param> /// <returns>SqlDataReader</returns> public static SqlDataReader RunProcedureDR(string connectionString, string storedProcName, IDataParameter[] parameters) { SqlConnection connection = new SqlConnection(connectionString); SqlDataReader returnReader; try { connection.Open(); SqlCommand command = BuildQueryCommand(connection, storedProcName, parameters); command.CommandType = CommandType.StoredProcedure; returnReader = command.ExecuteReader(CommandBehavior.CloseConnection); } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw new Exception(e.Message); } return returnReader; } #endregion #region =============獲取DataSet============== /// <summary> /// 執行查詢語句,返回DataSet /// </summary> /// <param name="SQLString">查詢語句</param> /// <returns>DataSet</returns> public static DataSet ExecuteDataSet(string connectionString, string SQLString) { using (SqlConnection connection = new SqlConnection(connectionString)) { DataSet ds = new DataSet(); try { connection.Open(); SqlDataAdapter command = new SqlDataAdapter(SQLString, connection); command.Fill(ds); } catch (SqlException ex) { connection.Close(); throw new Exception(ex.Message); } return ds; } } public static DataSet ExecuteDataSet(string connectionString, string strSQL, int Times) { using (SqlConnection conntion = new SqlConnection(connectionString)) { DataSet ds = new DataSet(); try { conntion.Open(); SqlDataAdapter da = new SqlDataAdapter(strSQL, conntion); da.SelectCommand.CommandTimeout = Times;//限制查詢時間 da.Fill(ds); } catch (System.Data.SqlClient.SqlException e) { conntion.Close(); throw new Exception(e.Message); } return ds; } } /// <summary> /// 執行查詢語句,返回DataSet /// </summary> /// <param name="SQLString">查詢語句</param> /// <returns>DataSet</returns> /// BU層得到對象實體用這個方法 public static DataSet ExecuteDataSet(string connectionString, string SQLString, params SqlParameter[] cmdParms) { using (SqlConnection connection = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand(); PrepareCommand(cmd, connection, null, SQLString, cmdParms); using (SqlDataAdapter da = new SqlDataAdapter(cmd)) { DataSet ds = new DataSet(); try { da.Fill(ds); cmd.Parameters.Clear(); } catch (System.Data.SqlClient.SqlException ex) { throw new Exception(ex.Message); } return ds; } } } //【調用方法】: //ArrayList arrayList = new ArrayList(); //arrayList.Add("strsql1"); //arrayList.Add("strsql2"); //... //arrayList.Add("strsqln"); //return DbHelperSQL.ExecuteManySqlDS(arrayList); /// <summary> /// 執行多條SQL語句返回多個DataSet /// </summary> /// <param name="arrayList">arrayList對象集合</param> /// <returns>多個數據集</returns> public static DataSet ExecuteManySqlDS(string connectionString, ArrayList arrayList) { DataSet set = new DataSet(); using (SqlConnection connection = new SqlConnection(connectionString)) { SqlCommand command = new SqlCommand(); command.Connection = connection; string table = "table"; SqlDataAdapter adapter = new SqlDataAdapter(); for (int i = 0; i < arrayList.Count; ++i) { command.CommandText = arrayList[i].ToString(); adapter.SelectCommand = command; adapter.Fill(set, table + i);// table + i 每個語句返回數據集的表名 } return set; } } /// <summary> /// 執行存儲過程返回DataSet /// </summary> /// <param name="storedProcName">存儲過程名</param> /// <param name="parameters">存儲過程參數</param> /// <param name="tableName">DataSet結果中的表名</param> /// <returns>DataSet</returns> public static DataSet RunProcedureDS(string connectionString, string storedProcName, IDataParameter[] parameters) { using (SqlConnection connection = new SqlConnection(connectionString)) { DataSet dataSet = new DataSet(); try { connection.Open(); SqlDataAdapter sqlDA = new SqlDataAdapter(); sqlDA.SelectCommand = BuildQueryCommand(connection, storedProcName, parameters); sqlDA.Fill(dataSet); } catch (System.Data.SqlClient.SqlException e) { connection.Close(); throw new Exception(e.Message); } return dataSet; } } public static DataSet RunProcedureDS(string connectionString, string storedProcName, IDataParameter[] parameters, string tableName) { using (SqlConnection connection = new SqlConnection(connectionString)) { DataSet dataSet = new DataSet(); connection.Open(); SqlDataAdapter sqlDA = new SqlDataAdapter(); sqlDA.SelectCommand = BuildQueryCommand(connection, storedProcName, parameters); sqlDA.Fill(dataSet, tableName); connection.Close(); return dataSet; } } #endregion #region ============數據庫事務處理============ /// <summary> /// 執行多條SQL語句,實現數據庫事務 /// </summary> /// <param name="SQLStringList">多條SQL語句</param> /// <returns>執行事務影響的行數</returns> public static int ExecuteSqlTran(string connectionString, List<String> SQLStringList) { using (SqlConnection conntion = new SqlConnection(connectionString)) { conntion.Open(); SqlCommand cmd = new SqlCommand(); cmd.Connection = conntion; SqlTransaction ts = conntion.BeginTransaction(); cmd.Transaction = ts; try { int count = 0; for (int n = 0; n < SQLStringList.Count; n++) { string strsql = SQLStringList[n]; if (strsql.Length > 1) { cmd.CommandText = strsql; count += cmd.ExecuteNonQuery(); } } ts.Commit();//提交數據庫事務 return count; } catch { ts.Rollback(); return 0; } } } /// <summary> /// 執行多條SQL語句,實現數據庫事務 /// </summary> /// <param name="SQLStringList">SQL語句的哈希表(key為sql語句,value是該語句的SqlParameter[])</param> public static void ExecuteSqlTran(string connectionString, Hashtable SQLStringList) { using (SqlConnection conn = new SqlConnection(connectionString)) { conn.Open(); using (SqlTransaction trans = conn.BeginTransaction()) { SqlCommand cmd = new SqlCommand(); try { //循環 foreach (DictionaryEntry myDY in SQLStringList) { string cmdText = myDY.Key.ToString(); SqlParameter[] parameter = (SqlParameter[])myDY.Value; PrepareCommand(cmd, conn, trans, cmdText, parameter); int result = cmd.ExecuteNonQuery(); //這里可以記錄該事務的執行結果 cmd.Parameters.Clear(); } trans.Commit(); } catch { trans.Rollback(); throw; } } } } #endregion #region 創建 SqlCommand 對象及創建執行命令參數 /// <summary> /// 為執行命令准備參數 /// </summary> /// <param name="cmd">SqlCommand 命令</param> /// <param name="conn">已經存在的數據庫連接</param> /// <param name="trans">數據庫事物處理</param> /// <param name="cmdText">SQL語句</param> /// <param name="cmdparams">返回帶參數的命令</param> public static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, string cmdText, SqlParameter[] cmdparams) { if (conn.State != ConnectionState.Open) {//判斷數據庫連接狀態 conn.Open(); } cmd.Connection = conn; cmd.CommandText = cmdText; if (trans != null) {//判斷是否需要事物處理 cmd.Transaction = trans; } cmd.CommandType = CommandType.Text; if (cmdparams != null) { foreach (SqlParameter parameter in cmdparams) { if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) && (parameter.Value == null)) { parameter.Value = DBNull.Value; } cmd.Parameters.Add(parameter); } } } /// <summary> /// 創建 SqlCommand 對象實例(用來返回一個整數值) /// </summary> /// <param name="storedProcName">存儲過程名</param> /// <param name="parameters">存儲過程參數</param> /// <returns>SqlCommand 對象實例</returns> private static SqlCommand BuildIntCommand(SqlConnection connection, string storedProcName, IDataParameter[] parameters) { SqlCommand command = BuildQueryCommand(connection, storedProcName, parameters); command.Parameters.Add(new SqlParameter("ReturnValue", SqlDbType.Int, 4, ParameterDirection.ReturnValue, false, 0, 0, string.Empty, DataRowVersion.Default, null)); return command; } /// <summary> /// 構建 SqlCommand 對象(用來返回一個結果集,而不是一個整數值) /// </summary> /// <param name="connection">數據庫連接</param> /// <param name="storedProcName">存儲過程名</param> /// <param name="parameters">存儲過程參數</param> /// <returns>SqlCommand</returns> private static SqlCommand BuildQueryCommand(SqlConnection connection, string storedProcName, IDataParameter[] parameters) { SqlCommand command = new SqlCommand(storedProcName, connection); command.CommandType = CommandType.StoredProcedure; foreach (SqlParameter parameter in parameters) { if (parameter != null) { // 檢查未分配值的輸出參數,將其分配以DBNull.Value. if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) && (parameter.Value == null)) { parameter.Value = DBNull.Value; } command.Parameters.Add(parameter); } } return command; } #endregion #region ============構造語句常用類============ /// <summary> /// Make input param. /// </summary> /// <param name="ParamName">Name of param.</param> /// <param name="DbType">Param type.</param> /// <param name="Size">Param size.</param> /// <param name="Value">Param value.</param> /// <returns>New parameter.</returns> public static SqlParameter MakeInParam(string ParamName, SqlDbType DbType, int Size, object Value) { return MakeParam(ParamName, DbType, Size, ParameterDirection.Input, Value); } public static SqlParameter MakeInParam(string ParamName, SqlDbType DbType, object Value) { return MakeParam(ParamName, DbType, 0, ParameterDirection.Input, Value); } /// <summary> /// Make input param. /// </summary> /// <param name="ParamName">Name of param.</param> /// <param name="DbType">Param type.</param> /// <param name="Size">Param size.</param> /// <returns>New parameter.</returns> public static SqlParameter MakeOutParam(string ParamName, SqlDbType DbType, int Size) { return MakeParam(ParamName, DbType, Size, ParameterDirection.Output, null); } /// <summary> /// 構建存儲過程參數 /// </summary> /// <param name="ParamName">參數名</param> /// <param name="DbType">參數類型(枚舉)</param> /// <param name="Size">參數大小</param> /// <param name="Direction">DataSet 的參數類型(枚舉)</param> /// <param name="Value">設置該參數的數值</param> /// <returns>New parameter.</returns> public static SqlParameter MakeParam(string ParamName, SqlDbType DbType, Int32 Size, ParameterDirection Direction, object Value) { SqlParameter param; if (Size > 0) { param = new SqlParameter(ParamName, DbType, Size); } else { param = new SqlParameter(ParamName, DbType); } param.Direction = Direction; if (!(Direction == ParameterDirection.Output && Value == null)) { param.Value = Value; } return param; } #endregion 構造語句常用類 #region =============由Object取值============= /// <summary> /// 取得Int值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static int GetInt(object obj) { if (obj.ToString() != "") return int.Parse(obj.ToString()); else return 0; } /// <summary> /// 獲得Long值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static long GetLong(object obj) { if (obj.ToString() != "") return long.Parse(obj.ToString()); else return 0; } /// <summary> /// 取得Decimal值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static decimal GetDecimal(object obj) { if (obj.ToString() != "") return decimal.Parse(obj.ToString()); else return 0; } /// <summary> /// 取得Guid值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static Guid GetGuid(object obj) { if (obj.ToString() != "") return new Guid(obj.ToString()); else return Guid.Empty; } /// <summary> /// 取得DateTime值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static DateTime GetDateTime(object obj) { if (obj.ToString() != "") return DateTime.Parse(obj.ToString()); else return DateTime.MinValue; } /// <summary> /// 取得bool值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static bool GetBool(object obj) { if (obj.ToString() == "1" || obj.ToString().ToLower() == "true") return true; else return false; } /// <summary> /// 取得byte[] /// </summary> /// <param name="obj"></param> /// <returns></returns> public static Byte[] GetByte(object obj) { if (obj.ToString() != "") { return (Byte[])obj; } else return null; } /// <summary> /// 取得string值 /// </summary> /// <param name="obj"></param> /// <returns></returns> public static string GetString(object obj) { return obj.ToString(); } #endregion #region ===========序列化與反序列化=========== /// <summary> /// 序列化對象 /// </summary> /// <param name="obj">要序列化的對象</param> /// <returns>返回二進制</returns> public static byte[] SerializeModel(Object obj) { if (obj != null) { BinaryFormatter binaryFormatter = new BinaryFormatter(); MemoryStream ms = new MemoryStream(); byte[] b; binaryFormatter.Serialize(ms, obj); ms.Position = 0; b = new Byte[ms.Length]; ms.Read(b, 0, b.Length); ms.Close(); return b; } else return new byte[0]; } /// <summary> /// 反序列化對象 /// </summary> /// <param name="b">要反序列化的二進制</param> /// <returns>返回對象</returns> public static object DeserializeModel(byte[] b, object SampleModel) { if (b == null || b.Length == 0) return SampleModel; else { object result = new object(); BinaryFormatter binaryFormatter = new BinaryFormatter(); MemoryStream ms = new MemoryStream(); try { ms.Write(b, 0, b.Length); ms.Position = 0; result = binaryFormatter.Deserialize(ms); ms.Close(); } catch { } return result; } } #endregion #region ==========Model與XML互相轉換========== /// <summary> /// Model轉化為XML的方法 /// </summary> /// <param name="model">要轉化的Model</param> /// <returns></returns> public static string ModelToXML(object model) { XmlDocument xmldoc = new XmlDocument(); XmlElement ModelNode = xmldoc.CreateElement("Model"); xmldoc.AppendChild(ModelNode); if (model != null) { foreach (PropertyInfo property in model.GetType().GetProperties()) { XmlElement attribute = xmldoc.CreateElement(property.Name); if (property.GetValue(model, null) != null) attribute.InnerText = property.GetValue(model, null).ToString(); else attribute.InnerText = "[Null]"; ModelNode.AppendChild(attribute); } } return xmldoc.OuterXml; } /// <summary> /// XML轉化為Model的方法 /// </summary> /// <param name="xml">要轉化的XML</param> /// <param name="SampleModel">Model的實體示例,New一個出來即可</param> /// <returns></returns> public static object XMLToModel(string xml, object SampleModel) { if (string.IsNullOrEmpty(xml)) return SampleModel; else { XmlDocument xmldoc = new XmlDocument(); xmldoc.LoadXml(xml); XmlNodeList attributes = xmldoc.SelectSingleNode("Model").ChildNodes; foreach (XmlNode node in attributes) { foreach (PropertyInfo property in SampleModel.GetType().GetProperties()) { if (node.Name == property.Name) { if (node.InnerText != "[Null]") { if (property.PropertyType == typeof(System.Guid)) property.SetValue(SampleModel, new Guid(node.InnerText), null); else property.SetValue(SampleModel, Convert.ChangeType(node.InnerText, property.PropertyType), null); } else property.SetValue(SampleModel, null, null); } } } return SampleModel; } } #endregion } }