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

  • 相关阅读:
    Java实现第九届蓝桥杯螺旋折线
    Java实现第九届蓝桥杯递增三元组
    强大的Mockito测试框架
    搭建eclipse环境下 Nutch+Mysql 二次开发环境
    mysql操作查询结果case when then else end用法举例
    查看mysql数据库及表编码格式
    mysql如何更改character-set-server默认为latin1
    (原创)Linux下MySQL 5.5/5.6的修改字符集编码为UTF8(彻底解决中文乱码问题)
    Ubuntu14连接MySql报错“can't connect to local mysql server through socket '/var/run/mysqld/mysqld.sock'”
    inux下设置mysql数据库字符集utf8
  • 原文地址:https://www.cnblogs.com/lexus/p/1260065.html
Copyright © 2011-2022 走看看