[转]技术储备之---C#使用Firebird嵌入版数据库

[img]http://blog.sciencenet.cn/upload/blog/images/2010/6/2010613152246995.jpg[/img]

[b][size=x-large]Firebird单击嵌入式非安装版使用[/size][/b]

Firebird特性介绍firebird是一个全功能的,强大高效的,轻量级,免维护的数据库。它很容易让您从单用户,单数据库升级到企业级的应用。

一个firebird数据库服务器能够管理多个独立的数据库,每一个数据库同时可支持多个客户端连结。总之:它是一个开源的,强大在,可以自由使用的数据库(即使是商业上的使用)

作为一款单文件型小型数据库,Firebird 具有很多吸引人的特征,比如支持事务、支持存储过程、触发器等,而且 Embeded 版本的 Firebird 在 .NET 开发中只需要拷贝两个文件:一个 fbembed.dll (非托管但不需要注册的动态链接库)和一个 ADO.NET Data Provider 的 FirebirdSql.Data.Firebird.dll。这些特征都非常适合那些需要在客户端存储一些数据,但又不想安装数据库(比如MSDE)软件的情形。

据称,在国外,需要使用客户端数据库的情况中,有30%左右的开发者选择Access,有30%的开发者选择MSDE 2000,有30%的开发者选择Embedded Firebird,剩余10%选择其他小型数据库,如SQLite,MySQL 等。

上面所说的Access,MSDE 2000,Embedded Firebird,SQLite等都是可以免费再分发(free redistributable)的数据库。相比而言,MSDE 2000 显著缺点是需要安装,最大优点是和服务器端的 SQL Server 编程模型一致,开发便利。Access的显著缺点是功能较少,不支持事务等常用功能,最大优点是简单、多数开发者都很熟悉,部署也很方便。SQLite支持事务,也是一款单文件数据库,比较不足的是 .NET Data Provider 还不是很成熟。Firebird则同时具有:单文件、部署简单不需安装(只需 XCOPY 几个文件)、支持事务、存储过程、触发器,.NET Data Provider比较稳定成熟等优点。

Firebird 本身有SuperServer和Embedded版本之分,后者只能本机访问,不接受TCP连接。对于开发者而言,从Embedded数据库切换到SuperServer,只需更改数据库连接串中的ServerType值就行。

[b][size=large]1.1 Firebird Data Provider For .NET 连接 Firebird 数据库[/size][/b]

参考:http://blog.csdn.net/HiSpring/archive/2010/02/17/5310243.aspx

1、下载 Firebird 嵌入式数据库:Firebird-2.5.0.25920-0_Win32_embed_pdb_RC2(ZIP格式,8.5MB) 下载解压到本地磁盘即可,无需安装。

2、利用可视化的数据库管理工具创建数据库:Firebird 的数据库管理工具有很多,本人使用了 IBManager,只有一个 EXE 文件,免安装。

3、配置数据库文件所在目录:从第1步中解压出来的目录下复制文件 firebird.msg 和 intl、udf 两个子目录的所有内容到放置数据库文件的目录下。注:数据库文件可以放置在任何可访问的目录上,不必和应用程序同一目录。

4、配置应用程序目录:从第1步中解压出来的目录下复制文件以下 6 个文件到应用程序目录:fbembed.dll、firebird.conf、ib_util.dll、icudt30.dll、icuin30.dll、icuuc30.dll。

5、引用 Firebird .NET Provider 的 dll :先下载 Firebird.Net Provider v2.5.1 (ZIP格式,200KB),解压,将其中的 FirebirdSql.Data.FirebirdClient.dll 添加引用到项目。

6、连接:个人也记不住连接字符串,直接使用 FbConnectionStringBuilder 创建连接字符串,具体代码如下:


using FirebirdSql.Data.FirebirdClient;



FbConnectionStringBuilder connBuilder = new FbConnectionStringBuilder();

connBuilder.UserID = userId;//设置一个值,嵌入式版本并不验证用户名。

connBuilder.ServerType = FbServerType.Embedded;//设置数据库类型为 嵌入式;

connBuilder.Database = dbFile;//数据库文件的目录;



using (FbConnection fbConn = new FbConnection(connBuilder.ConnectionString))

{

fbConn.Open();

Console.WriteLine("连接成功!");

fbConn.Close();

}



本次实验使用2.0版本

拷贝需要的文件至Debug目录

[img]http://blog.sciencenet.cn/upload/blog/images/2010/6/2010613152355448.jpg[/img]

[b][size=large]1.2创建Firebird数据库文件[/size][/b]


private void btn_NewDataBase_Click(object sender, EventArgs e)

{

FbConnection.CreateDatabase(GetConnectionString());

}

static string GetConnectionString()

{

FbConnectionStringBuilder cs = new FbConnectionStringBuilder();

cs.Database = "某某工作室.fdb";

cs.UserID = "SYSDBA";

cs.Password = "masterkey";

//cs.Charset = "UTF8"; //不设置任何的字符集,就可以避免出现中文路径不识别问题了

cs.ServerType = FbServerType.Embedded; // 设置数据库类型为嵌入式

return cs.ToString();

}



默认的数据库用户名为SYSDBA,默认密码为masterkey ,但是也可以创建自己的用户名和密码,如下代码所示:


static string GetConnectionString2()

{

FbConnectionStringBuilder cs = new FbConnectionStringBuilder();

cs.Database = "某某工作室2.fdb";

cs.UserID = "MOUSTUDIO";

cs.Password = "851021mou";

//cs.Charset = "UTF8"; //不设置任何的字符集,就可以避免出现中文路径不识别问题了

cs.ServerType = FbServerType.Embedded; // 设置数据库类型为嵌入式

return cs.ToString();

}




[b][size=large]1.3创建数据表[/size][/b]


using (FbConnection conn = new FbConnection(GetConnectionString()))

{

conn.Open();

using (FbCommand createTable = conn.CreateCommand())

{

createTable.CommandText = "create table Table_MouCH (id int, name varchar(20) character set gb2312)";

createTable.ExecuteNonQuery();

}

}



[b][size=large]1.4插入数据[/size][/b]


using (FbCommand insertData = conn.CreateCommand())

{

insertData.CommandText = "insert into Table_MouCH values (@id, @name)";

insertData.Parameters.Clear();

insertData.Parameters.Add("@id", FbDbType.Integer).Value = 10;

insertData.Parameters.Add("@name", FbDbType.VarChar, 200).Value = "某某";

insertData.ExecuteNonQuery();

}



[b][size=large]1.5读取数据[/size][/b]


using(FbCommand selectData = conn.CreateCommand())

{

selectData.CommandText = "select * from Table_MouCH";

using(FbDataReader r = selectData.ExecuteReader())

{

while(r.Read())

{

//string str_Temp = r.GetString(0);

string str_Temp = r.GetString(1);

MessageBox.Show(str_Temp);

}

}

}



使用注意解决问题:

(1) FDB中如何处理大小写?好像所有的字母都被搞成了大写?

(2) FDB中的所有字段似乎都只能用英文!而且还是小写的!

是否跟字符集设定有关???



[b][size=large]2010-6-13 中文路径问题解决[/size][/b]

参考:http://www.jocw.cn/sxsoftservice/Article_Print.asp?ArticleID=780

[img]http://blog.sciencenet.cn/upload/blog/images/2010/6/2010613152614214.jpg[/img]

源代码:


static string GetConnectionString()

{

FbConnectionStringBuilder cs = new FbConnectionStringBuilder();

cs.Database = "某某工作室.fdb";

cs.UserID = "SYSDBA";

cs.Password = "masterkey";

//cs.Charset = "UTF8"; //不设置任何的字符集,就可以避免出现中文路径不识别问题了

cs.ServerType = FbServerType.Embedded; // 设置数据库类型为嵌入式

return cs.ToString();

}



[b][size=large]2010-6-13 数据表中文字段处理成功[/size][/b]

只需要在创建数据表的时候指定数据表的字符集编码为gb2312即可。

下面是测试代码:

private void btn_ChTest_Click(object sender, EventArgs e)

{

using (FbConnection conn = new FbConnection(GetConnectionString()))

{

conn.Open();

using (FbCommand createTable = conn.CreateCommand())

{

createTable.CommandText = "create table Table_MouCH (id int, name varchar(200) character set gb2312)";

createTable.ExecuteNonQuery();

}

using (FbCommand insertData = conn.CreateCommand())

{

insertData.CommandText = "insert into Table_MouCH values (@id, @name)";

insertData.Parameters.Clear();

insertData.Parameters.Add("@id", FbDbType.Integer).Value = 10;

insertData.Parameters.Add("@name", FbDbType.VarChar, 200).Value = "某某";

insertData.ExecuteNonQuery();

}

using(FbCommand selectData = conn.CreateCommand())

{

selectData.CommandText = "select * from Table_MouCH";

using(FbDataReader r = selectData.ExecuteReader())

{

while(r.Read())

{

//string str_Temp = r.GetString(0);

string str_Temp = r.GetString(1);

MessageBox.Show(str_Temp);

}

}

}

}

MessageBox.Show("OK3!");

}



[img]http://blog.sciencenet.cn/upload/blog/images/2010/6/201061315272073.jpg[/img]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值