本文主要是介绍用ASP.NET访问Firebird嵌入版的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
当初对Access不满意,总在想找别的可替代的数据库。SQLite也太Lite了,后来发现Firebird的嵌入版,于是想着能否把嵌入版用到Firebird中。
查了相关资料,其实Firebird嵌入版与服务器版在应用中,其所建立的数据库在两都中是通用的,也就是说在服务器版中建的数据库,可以不加修改直接在嵌入版中使用。对于Firebird的.net开发接口,其实嵌入版与服务器版也只有比较少的区别,就是连接字符串。
以前写对服务器版的访问,其链接字符串示例如下:
User=SYSDBA;Password=masterkey;Database=c://data/db1.fb;DataSource=localhost;Port=3050;Dialect=3;Charset=UTF8;Role=;Connection lifetime=150;Pooling=true;MinPoolSize=0;MaxPoolSize=500;Packet Size=8192;ServerType=0;
查找相关文章得知,这里ServerType为0指服务器版,为1表示嵌入版。
开始实际操作。根据以往经验,把Firebird嵌入版文件复制到asp.net程序的bin目录,把数据提供程序的几个文件也复制到其中,并在项目中添加引用。
修改连接字符串ServerType参数,但并不能连接成功。去掉其中Pooling等Server才有的特征项,还是不行。
查了网上文章,用其中的连接字符串Builder来构建连接字符串,代码如下:
FbConnectionStringBuilder cs = new FbConnectionStringBuilder();
cs.Database = strData;
cs.UserID = “SYSDBA”;
cs.Password = “masterkey”;
cs.Charset = “UTF8″;
cs.Dialect = 1;
cs.ServerType = FbServerType.Embedded;
还是不行。其实我也隐约感觉到没有明确指明Firebird嵌入版程序的位置,但还不知道如何指明。
继续查找,终于有了结果。在用FbConnectionStringBuilder进行构建时,设置ClientLibrary就是设置其嵌入版程序的路径,示例如下:
cs.ClientLibrary = Server.MapPath(@”./bin/fbembed.dll”);
注意,这里不能用相对路径。
但这样页面还是出错,提示普不能对firebird文件进行写入,于是在NTFS上修改权限,对IIS_WPG和Internet来宾帐户设置写入权限,为保险,把Everyone的写入权限也设置了。当然,这样降低了安全性
至此,在ASP.NET中连接Firebird嵌入版成功。
转自:http://www.whodm.com/?p=100
这篇关于用ASP.NET访问Firebird嵌入版的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!