• [转]将数据库表存入内存中,随时调用


    注意,支持使用Sql语句和只使用表把,把数据库中的表加载到内存。注意,这里的内存是不会释放的。所以此组件是支持在asp.net服务器上使用的。从内存中取出来的表,是由你自定的。数据放置入内存之中,以HashTable对象为存贮对象。提取出来的数据为DataTable对象。也可只得到DataTable表中的一个值,如果你想要DataSet,也可以相互转换。详细使用请使看注解。

        /// <summary>
        /// 对基础数据进行处理。使用.net3.5框架
        /// 作者:若非轻寒 Email:ooofcu@hotmail.com
        /// 原理:把数据库中的表加入到内存对象HashTable中,需要
        /// 调用时,从HashTable对象中取出表或取出部份内容。
        /// </summary>
        public class DataDisposal
        {
            /*      //-----------------范          例-------------------
                    /// 作者:若非轻寒 Email:ooofcu@hotmail.com
                    DataDisposal g_DataDisposal= new DataDisposal("链接字符串");
                    //加载业务基础数据
                    g_DataDisposal.AddData("JJ_SFLBB");  
                    g_DataDisposal.AddData("JJ_SFWCYYB");
                    g_DataDisposal.AddData("JJ_DWXXB");
                    //判断指定名称的内称表是否存在
                    if(g_DataDisposal.Contains("TableName"))
                        return true;
                    //得到业务基础数据,取得整个表
                    DataTable dt = g_DataDisposal.GetData("JJ_DWXXB");

                    //操作得到数据,在指定的表中按字段取得一个值
                    string str = g_DataDisposal.GetTableValue("ID", "0", "DWMC", "JJ_DWXXB");

                    //返回一行数据,在指定的表中按主键取得一行值
                    DataRow dr = g_DataDisposal.GetDataRow("ID", "00", "JJ_DWXXB");

                     //还有一些其它方法,请自已看
            */

            //private ZIT.I_ZIT_Public g_DBOperation;     //数据访问组件

            private unsafe Hashtable hashTable = new Hashtable(); //用于存贮内存表集合
            private String sConnString = "";

            /// <summary>
            /// 内存数据表集合
            /// </summary>
            public Hashtable HashTableObj
            {
                get { return hashTable; }
                set { hashTable = value; }
            }
            /// <summary>
            /// 构造器
            /// </summary>
            /// <param name="sConnString">数据库链接字符串</param>
            public DataDisposal(string sConnString)
            {
                this.sConnString = sConnString;
                GC.SuppressFinalize(hashTable); //请求系统不要调用此对象的终结器(重要,保证此对象不被垃圾回收)
            }

            /// <summary>
            /// 判断本对象中指定的内存表是否存在
            /// </summary>
            /// <param name="sTableName">表名</param>
            public bool Contains(string sTableName)
            {
                return hashTable.ContainsKey(sTableName);
            }

            /// <summary>
            /// 得到本对象中内存表的数量
            /// </summary>
            /// <returns></returns>
            public int Count()
            {
                return hashTable.Count;
            }

            /// <summary>
            /// 向内存表中加载数据表,加载此表所有数据到内存。参数:数据库表名
            /// </summary>
            /// <param name="sTableName">数据表名</param>
            public void AddData(string sTableName)
            {
                try
                {
                    if (hashTable.Contains(sTableName))
                    {
                        //MessageBox.Show("已加载此表!程序中止!");
                        return;
                    }
                    string sSql = "select * from " + sTableName;
                    DataTable dtTemp = GetDataTable(sSql);
                    dtTemp.TableName = sTableName;
                    hashTable.Add(sTableName, dtTemp);
                    dtTemp = null;
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
            }

            /// <summary>
            /// 按SQL语句向内存表中加载数据表,需要自定一个内存表表名。参数:SQL查询语句,自定义内存表表名
            /// </summary>
            /// <param name="sSql">SQL语句</param>
            /// <param name="sTableName">自定一个内存表名,调用时就用这个表名调用</param>
            public void AddDataSql(string sSql, string sTableName)
            {
                try
                {
                    DataTable dtTemp = GetDataTable(sSql);
                    dtTemp.TableName = sTableName;
                    hashTable.Add(sTableName, dtTemp);
                    dtTemp = null;
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
            }

            /// <summary>
            /// 从内存表集合中取出一个指定表名的内存表
            /// </summary>
            /// <param name="sTableName">内存表表名</param>
            /// <returns></returns>
            public DataTable GetData(string sTableName)
            {
                try
                {
                    if (hashTable.Contains(sTableName))
                        return (DataTable)hashTable[sTableName];
                    else
                    {
                        //MessageBox.Show("指定内存表不存在!");
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
                return null;
            }

            /// <summary>
            /// 按条件返回一行数据
            /// select * from sTableName where sID=sValue
            /// </summary>
            /// <param name="sTableName">内存表名与数据库中的表名一样</param>
            /// <param name="sID">表字段名</param>
            /// <param name="sValue">表字段值</param>
            /// <returns>一行数据</returns>
            public DataRow GetDataRow(string sTableName, string sID, string sValue)
            {
                try
                {
                    //操作得到数据
                    DataTable dtTemp = GetData(sTableName);
                    LinqList<DataRow> rowsCollection = new LinqList<DataRow>(dtTemp.Rows);
                    //隐式类型
                    IEnumerable<DataRow> selectedRows = from r in rowsCollection
                                                        where r[sID].ToString() == sValue
                                                        select r;
                    dtTemp = null;
                    foreach (DataRow dr in selectedRows)
                    {
                        //操作
                        return dr;
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
                return null;
            }

            /// <summary>
            /// 按条件返回一行数据
            /// select * from sTableName where sID1=sValue1 and sID2=sValue2
            /// </summary>
            /// <param name="sTableName">内存表名与数据库中的表名一样</param>
            /// <param name="sID1">表字段名1</param>
            /// <param name="sValue1">表字段值1</param>
            /// <param name="sID2">表字段名2</param>
            /// <param name="sValue2">表字段值2</param>
            /// <returns>一行数据</returns>
            public DataRow GetDataRow(string sTableName, string sID1, string sValue1, string sID2, string sValue2)
            {
                try
                {
                    //操作得到数据
                    DataTable dtTemp = GetData(sTableName);
                    LinqList<DataRow> rowsCollection = new LinqList<DataRow>(dtTemp.Rows);
                    IEnumerable<DataRow> selectedRows = from r in rowsCollection
                                                        where r[sID1].ToString() == sValue1 && r[sID2].ToString() == sValue2
                                                        select r; //隐式类型
                    dtTemp = null;
                    foreach (DataRow dr in selectedRows)
                    {
                        //操作
                        return dr;
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }

                return null;
            }

            /// <summary>
            /// 按条件查询内存表中的数据
            /// select retValue from sTableName where sID=sValue
            /// </summary>
            /// <param name="retValue">要返回的表字段名 </param>
            /// <param name="sTableName">内存表名与数据库中的表名一样</param>
            /// <param name="sID">表字段名</param>
            /// <param name="sValue">表字段值</param>
            /// <returns>返回值为参数retValue所定义的字段,出现异常则提示错误,并返回""</returns>
            public string GetTableValue(string retValue,string sTableName,string sID, string sValue)
            {
                try
                {
                    //操作得到数据
                    DataTable dtTemp = GetData(sTableName);
                    LinqList<DataRow> rowsCollection = new LinqList<DataRow>(dtTemp.Rows);
                    IEnumerable<DataRow> selectedRows = from r in rowsCollection
                                                        where r[sID].ToString() == sValue
                                                        select r; //隐式类型
                    dtTemp = null;
                    foreach (DataRow dr in selectedRows)
                    {
                        //操作
                        return dr[retValue].ToString();
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
                return "";
            }

            /// <summary>
            /// 按条件查询内存表中的数据
            /// select retValue from sTableName where sID1=sValue1 and sID2=sValue2
            /// </summary>       
            /// <param name="retValue">要返回的表字段名</param>
            /// <param name="sTableName">内存表名与数据库中的表名一样</param>
            /// <param name="sID1">表字段名1</param>
            /// <param name="sValue1">表字段值1</param>
            /// <param name="sID2">表字段名2</param>
            /// <param name="sValue2">表字段值2</param>
            /// <returns>返回值为参数retValue所定义的字段,出现异常则提示错误,并返回""</returns>
            public string GetTableValue(string retValue, string sTableName,string sID1, string sValue1, string sID2, string sValue2)
            {
                try
                {
                    //操作得到数据
                    DataTable dtTemp = GetData(sTableName);
                    LinqList<DataRow> rowsCollection = new LinqList<DataRow>(dtTemp.Rows);
                    IEnumerable<DataRow> selectedRows = from r in rowsCollection
                                                        where r[sID1].ToString() == sValue1 && r[sID2].ToString() == sValue2
                                                        select r; //隐式类型
                    dtTemp = null;
                    foreach (DataRow dr in selectedRows)
                    {
                        //操作
                        return dr[retValue].ToString();
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }

                return "";
            }

            /// <summary>
            /// 删除内存中的特定表
            /// </summary>
            /// <param name="sTableName"></param>
            public void RemoveTable(string sTableName)
            {
                if (hashTable.Contains(sTableName))
                    hashTable.Remove(sTableName);
            }

            /// <summary>
            /// 删除内存中的所有表
            /// </summary>
            public void RemoveAllTable()
            {
                hashTable = null;
            }

            /// <summary>
            /// 将DataTable转化为DataSet
            /// </summary>
            /// <param name="dt">将要转化的DataTable</param>
            /// <returns>新的DataSet</returns>
            public DataSet DataTableToDataSet(DataTable dt)
            {
                DataSet ds = new DataSet();
                ds.Tables.Add(dt);
                return ds;
            }

            /// <summary>
            /// 内部方法,确定此模块得到数据库存唯一方法,
            /// 处理数据访问组件访问数据库得到数据
            /// </summary>
            /// <param name="sSql"></param>
            /// <returns></returns>
            private DataTable GetDataTable(string sSql)
            {
                return Query(sSql).Tables[0];     
            }

            /// <summary>
            /// 内部方法,执行查询语句,返回DataSet
            /// </summary>
            /// <param name="SQLString">查询语句</param>
            /// <returns>DataSet</returns>
            private DataSet Query(string SQLString)
            {
                using (OleDbConnection connection = new OleDbConnection(sConnString))
                {
                    DataSet ds = new DataSet();
                    try
                    {
                        connection.Open();
                        OleDbDataAdapter command = new OleDbDataAdapter(SQLString, connection);
                        command.Fill(ds, "ds");
                    }
                    catch (System.Data.OleDb.OleDbException ex)
                    {
                        throw new Exception(ex.Message);
                    }
                    return ds;
                }
            }
        }

        public class LinqList<T> : IEnumerable<T>, IEnumerable
        {
            IEnumerable items;
            public LinqList(IEnumerable items)
            {
                this.items = items;
            }
            #region
            IEnumerable<DataRow> Members;
            IEnumerator<T> IEnumerable<T>.GetEnumerator()
            {
                foreach (T item in items)
                    yield return item;
            }
            IEnumerator IEnumerable.GetEnumerator()
            {
                IEnumerable<T> ie = this;
                return ie.GetEnumerator();
            }
            #endregion
        }

  • 相关阅读:
    scanf和cin的返回值
    C++ STL中Map的按Key排序跟按Value排序
    name lookup of 'res' changed for new ISO 'res' scoping
    string中c_str()、data()、copy(p,n)函数的用法
    C中malloc的使用(转)
    codeforces 653B B. Bear and Compressing(dfs)
    codeforces 653A A. Bear and Three Balls(水题)
    hdu-5646 DZY Loves Partition(贪心)
    hdu-5645 DZY Loves Balls(水题)
    codeforces 655D D. Robot Rapping Results Report(拓扑排序+拓扑序记录)
  • 原文地址:https://www.cnblogs.com/aowind/p/1626938.html
Copyright © 2020-2023  润新知