Dictionary的一点用法

本文介绍如何利用C#中的Dictionary类提高数据导入效率。通过一次性读取所有公司名称及其ID,并将其存储为键值对,避免了每次导入记录时查询数据库的开销。
Dictionary <TKey, TValue >
类型参数
TKey 字典中的键的类型。TValue 字典中的值的类型。

Dictionary <(Of <( TKey, TValue >)>) 泛型类提供了从一组键到一组值的映射。 字典中的每个添加项都由一个值及其相关联的键组成。通过键来检索值的速度是非常快的,接近于 O(1),这是因为 Dictionary <(Of <( TKey, TValue >)>) 类是作为一个哈希表来实现的。

 

只要对象用作 Dictionary <(Of <( TKey, TValue >)>) 中的键,它就不能以任何影响其哈希值的方式更改。 使用字典的相等比较器比较时, Dictionary <(Of <( TKey, TValue >)>) 中的任何键都必须是唯一的。 键不能为 nullNothingnullptr   null 引用(在 Visual Basic 中为 Nothing) ,但是如果值类型 TValue 为引用类型,该值则可以为空。

 

Dictionary的基本用法。假如

需求:现在要导入一批数据,这些数据中有一个称为公司的字段是我们数据库里已经存在了的,目前我们需要把每个公司名字转为ID后才存入数据库。

分析:每导一笔记录的时候,就把要把公司的名字转为公司的ID,这个不应该每次都查询一下数据库的,因为这太耗数据库的性能了。

解决方案:在业务层里先把所有的公司名称及相应的公司ID一次性读取出来,然后存放到一个Key和Value的键值对里,然后实现只要把一个公司的名字传进去,就可以得到此公司相应的公司ID,就像查字典一样。对,我们可以使用字典Dictionary操作这些数据。

示例:SetKeyValue()方法相应于从数据库里读取到了公司信息。

 

 

/// <summary>
/// 定义Key为string类型,Value为int类型的一个Dictionary
/// </summary>
/// <returns></returns>
protected Dictionary<string, int> SetKeyValue()
{
Dictionary<string, int> dic = new Dictionary<string, int>();
dic.Add("公司1", 1);
dic.Add("公司2", 2);
dic.Add("公司3", 3);
dic.Add("公司4", 4);
return dic;
}


/// <summary>
/// 得到根据指定的Key行到Value
/// </summary>
protected void GetKeyValue()
{
Dictionary<string, int> myDictionary = SetKeyValue();
//测试得到公司2的值
int directorValue = myDictionary["公司2"];
Response.Write("公司2的value是:" + directorValue.ToString());
}

转载于:https://www.cnblogs.com/panjun/archive/2011/01/05/1926676.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值