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

本文介绍了一种从Access数据库加载字典信息到.NET应用程序的方法。通过使用OleDb进行数据交互,可以将数据库中的字典表加载到内存中以便快速访问。

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

直接上代码:

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");
        }

转载于:https://www.cnblogs.com/onedime/archive/2012/08/23/2652421.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值