• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

一个读取数据库字典的C#类

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

在做项目时,经常会有些字典信息保存到数据库中,在应用程序启动时需要加载到内存中,方便程序随时调用。

直接上代码:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.OleDb;

namespace TagReceiver
{
    class AccessHelper
    {
        string accessPath = "";

        /// <summary>
        /// 读取LOC_OWNER表
        /// </summary>
        /// <returns></returns>
        public SortedList GetCodeSet(string connectionString, string tableName)
        {
            string cmdText = String.Format("select * from {0}", tableName);
            SortedList sl = new SortedList();
            // 创建数据库连接 
            OleDbConnection conn = new OleDbConnection(connectionString);

            // 创建command对象并保存sql查询语句 
            OleDbCommand cmd = new OleDbCommand(cmdText, conn);
            try
            {
                conn.Open();

                // 创建datareader 对象来连接到表单 
                OleDbDataReader reader = cmd.ExecuteReader();

                // 循环遍历数据库 
                while (reader.Read())
                {
                    sl.Add(reader.GetString(0), reader.GetString(1));
                }

                // 关闭reader对象 
                reader.Close();

                // 关闭连接,这很重要 
                conn.Close();
            }

            // 一些通常的异常处理 
            catch (OleDbException e)
            {
                LogHelper lh = new LogHelper();
                lh.WriteLine(".\\Logs\\DBException.log", e.Errors[0].Message);
            }

            return sl;
        }
    }
}

如何调用:

        SortedList slLocOwner = new SortedList();
        SortedList slLocType = new SortedList();
        SortedList slFreightCarFactory = new SortedList();
        SortedList slPassengerCarFactory = new SortedList();

        private void MainForm_Load(object sender, EventArgs e)
        {
            ...
            LoadDict();
            ...
        }


        /// <summary>
        /// 加载数据库字典
        /// </summary>
        private void LoadDict()
        {
            string connectionString = String.Format("provider=microsoft.jet.oledb.4.0;data source={0}\\Dict.mdb", Application.StartupPath);
            AccessHelper ah = new AccessHelper();
            slLocOwner = ah.GetCodeSet(connectionString, "LOC_OWNER");
            slLocType = ah.GetCodeSet(connectionString, "LOC_TYPE");
            slFreightCarFactory = ah.GetCodeSet(connectionString, "CAR_FACTORY");
            slPassengerCarFactory = ah.GetCodeSet(connectionString, "PASSENGERCAR_FACTORY");
        }

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#扩展方法学习c#扩展方法奇思妙用发布时间:2022-07-13
下一篇:
使用C#创建Windows服务发布时间:2022-07-13
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap