问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Firebird Maestro好不好

发布网友 发布时间:2022-05-03 20:09

我来回答

2个回答

懂视网 时间:2022-05-04 00:30

虽然Firebird总体上是比Access好,但是没有传说的那么好,至少在Net环境下。 1、测试环境 A、系统环境 操作系统:Windows XP Professional Server Pack 2 CPU:Intel(R) Pentium(R) 4 CPU 3.00GHZ 2.99GHZ 内存:1G B、代码环境 NET2.0、Access2003、Firebir

虽然Firebird总体上是比Access好,但是没有传说的那么好,至少在Net环境下。

1、测试环境

  A、系统环境

  操作系统:Windows XP Professional Server Pack 2

  CPU:Intel(R) Pentium(R) 4 CPU 3.00GHZ 2.99GHZ

  内存:1G

  B、代码环境

  NET2.0、Access2003、Firebird2.1、

  Firebird的NET2.0访问API(FirebirdSql.Data.FirebirdClient.dll)

2、数据库

EmployeeInfo表:

CREATE TABLE EMPLOYEEINFO(
EID Integer NOT NULL,
ENAME Varchar(50),
ETELEPHONE Varchar(50),
EMOBILE Varchar(50),
EADDRESS Varchar(200),
EWORK Varchar(50),
ECOMPANY Varchar(50),
EAGE Integer,
ESCHOOL Varchar(50),
EBIRTHDAY Date,
EFAVOURATE Varchar(500),
ISMVP Integer,
ELEVEL Integer,
ENABLE_FLAG Integer,
CONSTRAINT EMPLOYEEINFO_NAME PRIMARY KEY (EID)
);

3、测试代码

  见附带文件

4、性能比较

  下面的数字是以毫秒为单位的,对于两个数据库连接的性能在4.1中有记录,因为其他的操作连接的性能基本相同,所以在其他的比较中省略了。

  新增操作:需要从数据表中获取ID,所以都需要执行ExecuteScalar

  Access:SELECT max(EId) + 1 FROM EmployeeInfo

  Firebird:SELECT first 1 GEN_ID( EMPLOYEEINFO_KEY_GEN, 1) FROM RDB$GENERATORS

  预编优化:这种方式是采用IDbCommand的Prepare方法来进行的。

  4.1、单条数据的操作比较

  1、新增操作

IDbConnection.Open() IDbCommand.ExecuteScalar() IDbCommand.ExecuteNonQuery()
Access 174.238416 102.448561 41.695030
159.298931 101.921224 41.537487
185.202748 102.383310 36.008230
FireBird 381.801163 59.864800 38.652679
360.196079 69.475482 39.371224
343.838800 60.606686

39.241575

  2、  修改操作

Access FireBird
IDbCommand.ExecuteNonQuery() 125.531627 88.544622
105.508891 88.177334
145.817176 107.016208
4.2、100条数据的操作比较

  1、新增操作

IDbCommand.ExecuteScalar() IDbCommand.ExecuteNonQuery()
Access 275.494317 234.020361
261.396954 237.707107
252.611140 253.758009
预编译优化 124.001096 100.539268
124.581257 98.269848
125.422189 99.034516
预编译+事务控制 156.688199 99.945657
116.741034 80.133735
113.269134 82.601144
FireBird 838.318433 969.816292
887.597984 1064.949756
818.385955 1022.706634
预编译优化 308.331690 437.868342
283.292181 551.306577
222.096816 455.877916
预编译+事务控制 70.281354 109.981409
72.199458 96.185741
69.851572 91.551454

  2、  修改操作

Access FireBird
IDbCommand.ExecuteNonQuery() 411.009308 913.508742
396.797053 868.117194
399.259210 912.881623
预编译优化 177.652866 692.759320
163.982479 709.243510
171.324164 644.216015
预编译+事务控制 158.654429 106.195976
154.795059 101.715139
157.486357 104.424021
4.3、1000条数据的操作比较

  1、新增操作

IDbCommand.ExecuteScalar() IDbCommand.ExecuteNonQuery()
Access 1651.840012 2133.541653
1663.862358 2144.262530
1631.403159 2135.223692
预编译优化 796.962979 808.875114
785.243696 793.758126
809.209726 797.399235
预编译+事务控制 728.416438 610.310033
873.088523 898.503055
673.583191 603.249033
FireBird 7737.366552 9359.178169
7308.689064 10904.423101
7724.148976 11846.604215
预编译优化 3716.587264 5723.248900
3234.737922 5430.311542
2686.714810 4821.239747
预编译+事务控制 522.050014 642.658276
522.211388 665.879242
532.323116 658.373523

  2、  修改操作

Access FireBird
IDbCommand.ExecuteNonQuery() 3290.740559 7873.507740
3991.333695 7822.996734
3293.068174 7116.759956
预编译优化 1398.160890 6482.893171
1254.979979 6302.055985
1245.802121 6272.648019
预编译+事务控制 1097.316477 648.313099
1221.636742 648.390276
1104.532568 648.983446
4.4、10000条数据的操作比较

  1、新增操作

IDbCommand.ExecuteScalar() IDbCommand.ExecuteNonQuery()
Access 15321.344697 20695.870283
15522.056899 20775.041631
15319.349251 20727.514825
预编译优化 10627.689828 9980.130051
11161.361432 10432.259290
10580.619317 9925.817398
预编译+事务控制 6191.647891 6037.020082
6855.991305 6306.552880
6659.638395 6042.067384
FireBird 92770.835360 119561.011190
115369.304783 143528.391259
135761.012112 165465.676440
预编译优化 61204.197587 94345.156610
36930.112494 57278.146122
40012.081468 66210.081814
预编译+事务控制 5407.627206 6910.738469
5488.005238 7106.846560
5524.538831 6740.408060

  2、  修改操作

Access FireBird
IDbCommand.ExecuteNonQuery() 39694.855804 99310.751707
35354.716525 90011.911178
36534.236655 91112.061482
预编译+事务控制 10469.019093 7230.535415
10444.395741 7682.581104
10329.116616 7390.059610
4.5、100000条数据的操作比较

  1、新增操作

  IDbCommand.ExecuteScalar()

IDbCommand.ExecuteNonQuery()
Access

  198287.389450

223781.708768

  207229.904897

227152.302183

  236267.203150

251924.067059
预编译优化

  75745.455466

80136.166440

  80215.392531

84041.511179

  83531.057454

85371.502942
预编译+事务控制

  73753.320106

62696.035496

  70442.642879

69222.947557

  79447.569370

70056.168140
FireBird

  >30分钟

预编译优化 297619.975597

  551716.871984

预编译+事务控制 50412.421478

  62230.369322

52912.052985

  69931.034354

52509.019944

  66763.649792

  2、  修改操作

Access FireBird
IDbCommand.ExecuteNonQuery() 332451.315712

  1260805.499906

347068.025903
预编译优化 164528.339360 643502.447928
预编译+事务控制 108129.478762 81140.664313
4.6、500000条数据的操作比较

  1、新增操作

IDbCommand.ExecuteScalar()

  IDbCommand.ExecuteNonQuery()

预编译优化Access 479207.809593

  465971.617839

377229.922041

  367370.094465

预编译+事务控制 336857.065763

  316500.809166

预编译优化FireBird

  >60分钟

预编译+事务控制

  273555.344525

361675.703063

  2、  修改操作

Access FireBird
预编译+事务控制 512516.135296 473002.155994
4.7、100条数据的查询比较
Access FireBird
SELECT * FROM table 561.603041 705.621894
528.617866 804.226516
SELECT * From table WHERE name like ‘%...%’ 531.510943 720.582087
525.499398 761.811122
4.8、1000条数据的查询比较
Access FireBird
SELECT * FROM table 588.116789 771.333159
615.835833 743.432148
SELECT * From table WHERE name like ‘%...%’ 557.460599 715.724471
564.812336 724.736215
4.9、10000条数据的查询比较
Access FireBird
SELECT * FROM table 1134.614770 1337.971064
1015.374508 1261.249305
SELECT * From table WHERE name like ‘%...%’ 737.451880 925.413277
751.952307 910.842727
4.10、100000条数据的查询比较
Access FireBird
SELECT * FROM table 6501.658483 6335.985464
5426.486788 6899.610531
SELECT * From table WHERE name like ‘%...%’ 3204.588434 3298.303960
3203.261492 3810.441583
4.11、500000条数据的查询比较
Access FireBird
SELECT * FROM table 28380.649119 34032.733181
28227.096199 34557.834127
SELECT * From table WHERE name like ‘%...%’ 18065.770127 19266.049635
18412.904426 17163.350933
4.12、数据库文件增长量的比较

  Access文件大小的增长是非常恐怖的,1000000条左右的数据基本上可以达到Access的极限(2G)

  Firebird文件大小的增长和Access比较起来,比Access要小很多,基本上是差了几个级别

  下面是分别进行大数量操作后的文件情况:

  Firebird 94808KB

  Access  1123424KB

  在不压缩数据库的前提下,Access增加100W左右的数据达到2G,Firebrid增加1000W左右的数据达到2G。

5、测试总结

  根据上面的性能比较,可以得出以上几点结论:

  1. 对于大批量的数据操作,一定要采用预编译或批量提交的方式进行操作,如果是在Firebird中,一定加事务进行处理,因为在Firebird中,有事务的性能可以提升6-10倍左右。在Access中,虽然性能提升不多,但是还是最好都加上事务控制。这一方面增加操作的原子性,并且也减少数据库的读写次数。
  2. Access一般支持2G左右的数据,当数据量超过这个限制后,Access不能写入数据。所以当数据量在2G下的时候才选用。Firebird对于数据的支持大于/等于16G,而且在优化后的整体性能要强于Access。
  3. Access在没有压缩的前提下,如果大批量的进行数据操作(新增/修改),那么数据大小的增长是是Firebird的几倍,一般连续增长100W多的数据就不能再插入数据了。而Firebird 在这点上是很好的,同时也没有限制。

热心网友 时间:2022-05-03 21:38

优点:比较轻量,数据库就一个文件,方便拷贝, 跨平台,一般的小型网站,管理系统都可以用,应该比access方便,数据库本身也很强大,支持热备份;
缺点:相关的资料文档太少了,可能对不熟悉数据的同学有门槛。
ibexpert能*想干的很多,差一些的有免费的ibconsole,功能也够用。
请采纳
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
创新5.10060声卡怎么关闭,为什么音质变得很差?我用的是KX 我已经装了声卡,和Kx管理器。可声音听见还是那么幼稚。怎么把声音调的... ...装不上KX3550,声卡是 创新5.1的 装完KX3550重启以后,提示 初始化... 我买了一个创新5.1 0060声卡,玩龙之谷游戏就声音不完全,只有背景音乐... 声卡5.10060KX驱动3550调试怎么弄 win11玩csgo游戏一直闪退什么原因 win11玩csgo游戏一直闪退的解决... 习惯养成心得体会 饥荒ios高脚鸟蛋怎么孵化高脚鸟怎么养 故事的力量可以从什么角度来分析? 地震前为什么要出现地震云 Android 获取手机内部存储的路径 android系统中,有关框架层的代码应该在以下哪个目录中 如何获取Android设备挂载的所有存储器 android 怎么从storage中获取文件数据 android系统怎样设置内部存储的访问权限 k40为什么data进不去 rman备份时候show all里控制文件我已经制定路径了,为什么这里显示这个路径 oracle 为什么要使用delete all input 如何手动建立Oracle监听器 oracle中 alter system register什么意思 电脑解决方案 解决方案行销工程师做什么 中国的民生问题和解决方案 电脑显示联机检查解决该问题的解决方案,该怎么办? 在项目中,你认为“目标,需求,解决方案”三者的顺序是什么?为什么?_问一问 【解决方案】 方案一: 新建一个记事本文件,把后缀名改成bat格式。在记事本中写入以下代码: @echo off win10更新系统后,电脑每次开机都要等差不多十分钟黑屏,才能显示桌面,求解决方法 我在桌面图标上点击右键,不显示菜单,闪一下就不见了.怎么办? 离婚最好的解决方案是什么 gameoverview是什么意思 急。。急。。急。。。目前使用较普遍的数据库软件有哪些?各自有什么特点! 除了access和mySQL外,还有哪些系统自带的,或者小巧方便的数据库系统用于程序开发的? 除了SQL Server数据库还有哪些数据库 心脏支架partner和firebird是什么牌子的?是国产还是进口? 原子经济性中的e-factor是什么? delphi怎么创建带密码的ACCESS数据库? android service权限问题 如何在服务器资源管理器中添加access的连接? 如何给eclipse里面添加权限啊? accesspermission 是做什么用的? Android权限添加了但是还是报错,求助各位 我开网站出现了You don't have permission to access / on this server应该怎样设置?~~ 如何在服务器上连接access数据库 打包发布apk怎么解决android.permission.access android.permission.access_superuser在 manifest中未定义。 软件出现这个怎么设置,本人知道qq开始的 为什么需要 android.permission.ACCESS android怎么在androidmanifest.xml文件中注册权限 如何为ContentProvider添加访问权限 Access Denied. 出现错误,应该怎样解决!详细点! access查询向导如何更改数据类型,为什么我的总是自动变成数字类型,我想让他是文本类型