Berkeley DB .net 进行添加和更新操作
2008-08-04 13:59
471 查看
使用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 Class18
{
static void Main(string[] args)
{
People a=new People()
{
Age=20,
Name="30"
};
Db db = new Db(DbCreateFlags.None);
try
{
DbFile dbf = db.Open(null, @"Tasks.asap", null, DbType.Hash, Db.OpenFlags.Create, 0);
MemoryStream stream = new MemoryStream();
BinaryFormatter formatter = new BinaryFormatter();
formatter.Serialize(stream, a);
DbEntry _key = DbEntry.InOut(Encoding.UTF8.GetBytes("1"));
DbEntry _data = DbEntry.InOut(stream.ToArray());
if (dbf.Put(null, ref _key, ref _data) != 0)
Console.Write("{0}:输入错误", "");
//dbf.Put(null, ref _key, ref _data);
dbf.Sync();//数据更新
}
catch (Exception ex)
{
Console.WriteLine("打开数据库Tasks.p失败");
}
db.Close();
}
}
}
遍历查看结果
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();
}
}
}
插入或是更新的代码片段:
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 Class18
{
static void Main(string[] args)
{
People a=new People()
{
Age=20,
Name="30"
};
Db db = new Db(DbCreateFlags.None);
try
{
DbFile dbf = db.Open(null, @"Tasks.asap", null, DbType.Hash, Db.OpenFlags.Create, 0);
MemoryStream stream = new MemoryStream();
BinaryFormatter formatter = new BinaryFormatter();
formatter.Serialize(stream, a);
DbEntry _key = DbEntry.InOut(Encoding.UTF8.GetBytes("1"));
DbEntry _data = DbEntry.InOut(stream.ToArray());
if (dbf.Put(null, ref _key, ref _data) != 0)
Console.Write("{0}:输入错误", "");
//dbf.Put(null, ref _key, ref _data);
dbf.Sync();//数据更新
}
catch (Exception ex)
{
Console.WriteLine("打开数据库Tasks.p失败");
}
db.Close();
}
}
}
遍历查看结果
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 XML文档进行添加删改操作的实例代码
- 用Ado.net可以对数据进行批量添加或更新
- 关于SubSonic3.0插件使用Json反序列化获得的实体进行更新操作时,只能执行添加而不能执行修改(编辑)操作的处理
- word2013 交叉引用添加参考文献的尾注编号,通过查找 ^# 替换为 [^&] 的方式添加中括号,在进行“更新域”操作后,中括号消失。
- 在asp.net中,我用c#进行AD操作,添加用户
- ASP.NET MVC对WebAPI接口操作(添加,更新和删除)
- Asp.net XML文档进行添加删改操作的实例代码
- asp.net 对Execl 的添加,更新操作
- asp.net 对Execl 的添加,更新操作
- 关于SubSonic3.0插件使用Json反序列化获得的实体进行更新操作时,只能执行添加而不能执行修改(编辑)操作的处理
- asp.net Execl的添加,更新操作实现代码
- asp.net 对Execl 的添加,更新操作
- asp.net 对Execl 的添加,更新操作
- asp.net Execl的添加,更新操作实现代码
- ASP.NET 中数据库操作之-添加-更新-删除和异常捕获。
- 在GridView中进行编辑,更新和取消操作
- poi对excel进行添加图片操作
- 用ASP.NET对IIS中的虚拟目录进行操作
- asp.net 对xml文件的读写,添加,修改,删除操作
- asp.net 对xml文件的读写,添加,修改,删除操作