Berkeley DB 基本使用.

最近在写蜘蛛。需要一张庞大的url表来记录各种url被线程的读取状况,因此需要连续的请求,以及多线程的并发操作等。
很显然,sqlserver并不能完全的满足需求。
推荐一下Berkeley DB
Berkeley DB相当于存储于本地硬盘的一个大的Hash表,由Key,Value构成.

需要下载的相关内容
Berkeley DB 4.5.20
Berkeley DB for .NET 0.95


基本操作
 // 添加数据到DBD数据库
        public  bool Add(string key,string obj)
        {
            string DbPath = @"e:\search\data\data.db";
            Db db = new Db(DbCreateFlags.None);
            DbEntry wKey = DbEntry.InOut(Encoding.UTF8.GetBytes(key));
            DbEntry wData = DbEntry.InOut(Encoding.UTF8.GetBytes(obj));
            DbFile dbf = db.Open(null, DbPath, null, BerkeleyDb.DbType.BTree, Db.OpenFlags.Create, 0);
            WriteStatus wStatus = dbf.Put(null, ref wKey, ref wData);
            dbf.Sync();
            db.Close();
            if (wStatus == WriteStatus.Success)
            {
                return true;
            }
            else
            {
                return false;
            }

        }

        // 根据key返回值
        public string GetVal(string key)
        {
            string result = string.Empty;
            DbEntry rData = DbEntry.Out(new byte[2048]);
            DbEntry rKey = DbEntry.InOut(Encoding.UTF8.GetBytes(key));
            Db db = new Db(DbCreateFlags.None);
            DbFile dbf = db.Open(null, DbPath, null, BerkeleyDb.DbType.BTree, Db.OpenFlags.Create, 0);
            ReadStatus rStatus = dbf.Get(null, ref rKey, ref rData, DbFile.ReadFlags.None);
            db.Close();
            if (rStatus == ReadStatus.Success)
            {
                result = Encoding.UTF8.GetString(rData.Buffer, 0, rData.Size);
            }
            return result;
        }

转载于:https://www.cnblogs.com/yinhl/archive/2007/11/12/956971.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值