zoukankan      html  css  js  c++  java
  • Berkeley DB .net 进行添加和更新操作

    使用hash格式的put方法,当key已经存在时,则更新该key的键值,若没有该key,则向数据库中插入一条新的记录,demo代码如下:

    插入或是更新的代码片段:

    Code

    遍历查看结果

    using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Runtime.Serialization.Formatters.Binary;
    using System.Text;
    using BerkeleyDb;

    namespace BerkeleyDBDemo
    {
        public class Class19
        {
            static void Main(string[] args)
            {
                //遍历数据
                using (Db db = new Db(DbCreateFlags.None))
                {
                    //这里如果应用Db.OpenFlags.Create则在启动后会覆盖同名文件,并新建同名文件
                    //Db.OpenFlags.Truncate会清空数据库
                    DbHash dbf = (DbHash)db.Open(null, @"Tasks.asap", null, DbType.Hash,
        Db.OpenFlags.ThreadSafe, 0);

                    using (DbHashCursor cursor = dbf.OpenCursor(null, DbFileCursor.CreateFlags.None))
                    {
                        foreach (KeyDataPair kdp in cursor)
                        {
                            //int k = BitConverter.ToInt32(kdp.Key.Buffer, 0);
                            //Console.WriteLine("k={0}", k.ToString());
                            string k = Encoding.UTF8.GetString(kdp.Key.Buffer, 0, kdp.Key.Size);
                            Console.WriteLine("key={0}", k);
                            BinaryFormatter bf = new BinaryFormatter();
                            MemoryStream stream = new MemoryStream();
                            stream.Write(kdp.Data.Buffer, 0, kdp.Data.Size);
                            stream.Seek(0, SeekOrigin.Begin);
                            People p2 = (People)bf.Deserialize(stream);
                            Console.WriteLine("Age={0}", p2.Age);
                            Console.WriteLine("Name={0}", p2.Name);


                        }
                    }

                }
                Console.ReadLine();
            }
        }
    }

  • 相关阅读:
    ASP.NET WebForm Best Practice 之ViewState
    我会为开源和自由学习,使用JAVA.但我决不会为了开源和自由放弃.NET
    EXT调用ASP.NET AJAX WebService
    我的2007
    博客园迎新春对联
    NBear.Mapping使用教程(2):NBear.Mapping的配置系统
    NBear.Mapping使用教程(3):第一个简单例子
    使用LumaQQ来开发QQ机器人
    解决方案迁移到Visual Studio 2008的一些相关问题
    NBear.Mapping使用教程(4):实体对象与ADO.NET对象的转换
  • 原文地址:https://www.cnblogs.com/lexus/p/1260065.html
Copyright © 2011-2022 走看看