IBX 常见问题解答(译)

IBX 常见问题解答

  • 我在哪里能下载到最新版本的IBX?

  • IBX中的ReFresh是怎样执行的?

  • IBX中的RecordCount是怎样执行的?

  • 为什么把一个DBLookUpComboBox与一夜IBQuery连接时,我在下拉框中只看到一条记录?

  • 为什么应该避免使用IBTABLE?

  • 为什么不能看到其他人做的更新?

  • 为什么当我提交或回滚事务时,我的数据集关闭了?

  • 在一个主/细表关系中使用缓存更新,当我Post时细表怎么不见了?

Q:我在哪里能下载到最新版本的IBX?

A:这里

Top

Q:IBX中的ReFresh是怎样执行的?

A:BDE相反, IBXRefresh方法只刷新当前记录(数据集的游标指向的记录),这是为了减小网络流量。如果想更新多条记录,你需要关闭再重新打开数据集。

Top

Q:IBX中的RecordCount是怎样执行的?

A:Recordcount返回得到的记录数。当打开一个数据集后,如果是空的数据集就返回0否则返回1,这是因为IBX只有当明确要求得到下一条记录时才取新的记录。当调用FetchAll方法(实际中并不推荐这样)后,RecordCount将返回数据集中记录的总数。

IBX, 不应该靠使用RecordCount得到存在的记录数,其实只是ParadoxDbase需要它。如果你确实需要知道数据集中的总数,这里有一个技巧:不要调用FetchAll方法,大多数情况下只要在一个单独的TIBSQL中写一条类似"SELECT COUNT(*)"的语句然后执行就可以了。

Top

Q:为什么把一个DBLookUpComboBox与一个IBQuery连接时,我在下拉框中只看到一条记录?

A:再说一遍,IBX只有当明确要求得到下一条记录时才取记录。在DBLookupCombo使用中,企图在填下拉框之前依靠RecordCount来测量下拉区域的个数是不正确的方法(参见前一个问题)。

解决这个问题,只要在combo AfterOpen事件中写上下面的代码就可以了(强行获得记录以增加RecordCount的值):

{
    MoveBy(MyDBLookupCombo->DropDownCount);
       First();
}

Top

Q:为什么应该避免使用IBTABLE?

A:简单的说,TIBTableC/S系统不友好,IBX包含这个组件只是出于兼容的原因。TIBDataSet是它的直接代替品。

详细一点,Table范例来自基于文件的数据库,如Paradox。基本上不管表位于哪里,所有的行和列(一般还有所有的索引信息)都被存在本地,这样SQL 引擎(如BDE)才能处理数据。既然不管怎样,所有的数据都要在本地重新存储,TTable 被设计为能在那种环境下很好的工作。
C/S
范例意味着你让服务器来处理你需要的数据查询且只返回用户所需要的数据。 比如,你只需要返回5个列中的3个或者1000条记录中的100条,等等。在这种C/S 环境中,Table 范例可能会阻塞网络而且性能一点也不好。
要获得需要的数据,你只需填写TIBDatasetSelectSQL属性,右键单击TIBDataset选择DataSet Editor可以帮助你写InsertSQL, ModifySQL, DeleteSQL RefreshSQL。一旦把它们填上,你就得到了一个完整的可更新的结果集。这样,在速度,网络流量和存储方面都比一个基于Table的范例所花的开销要小。

Top

Q:为什么不能看到其他人做的更新?

A:首先,检查你的事务隔离机制是否为Read Committed。如果是Snapshot模式(IB默认的设置 ,你就总是得到一个和刚开始一致的数据库视图——你看不到其他用户做的更新。提示:双击你的TIBTransaction组件,把事务隔离模式改为Read Committed

然后,确保你的应用程序在所有更新操作后明确的提交了一个事务,使用CommitRetaining Commit 之一即可。

最后,如果其他用户执行了一些更新而你的数据集已经在你的电脑上打开了,你只有关闭然后重新开启你的数据集才能看到那些更改;或者已更新的记录刚好是你当前访问的记录,那么调用Refresh方法也可以看到这条记录的更新后的样子。

Top

Q:为什么当我提交或回滚事务时,我的数据集关闭了?

A:简单的说,对于IBX,这很正常。使用CommitRetainingRollbackRetaining可以保持你的数据集处于打开状态。

详细的解释是,在IBX,如果你调用CommitRollback,会结束客户端一个存在事务。因此,所有依赖那个事务的东西都会被重置或变为无效。没有事务,IB不知道你应该看到的记录的版本——也就是说,IB不能确定你的版本隔离机制是ReadCommitted还是Snapshot

实际上有两方面依赖于一个事务:1) 所有已经post给服务器的改变; 2) 所有当前打开的“游标”。

IB中的游标是你执行一个有多条记录返回的查询语句后得到的东西。通过请求获取记录,游标产生作用,直到游标用尽。所有打开的游标依赖于一个事务当前的句柄,那么如果终止那个事务,游标就无效了。

所以,当你调用CommitRollback时,IBX做的事情就是关闭你打开的所有数据集以避免出现无效游标的错误。这是因为,IBX没有像BDEIBO那样在保持数据集开启和终止事务之间提供一个隔离层。

如果你想让你的数据集一直打开,则推荐使用CommitRetainingRollbackRetaining来处理你工作的逻辑单元以避免关闭数据集;当你要释放服务器资源时,则要使用CommitRollback,这样垃圾收集就会运行。当然,你还是应该尽量经常执行CommitRollback

Top

Q:在一个主/细表关系中使用缓存更新,当我Post时细表怎么不见了?

A:这是Tdataset级别上的行为。当你进入编辑模式(或者ApplyUpdates)时,数据链接传递一个消息:游标已经被重置。这个消息使细表查询关闭且在新的设置上重新打开。解决的方法只有终止数据链接:在主表更新前,设置细表的数据源(DataSource)为空即可。

Top

英文原文:http://ib.freeservers.com

InterBase Express FAQ

  • Where can I download latest version of IBX?

  • How does Refresh work in IBX?

  • How does RecordCount work in IBX?

  • When connecting a DBLookUpComboBox to a TIBQuery, I see just one record in the drop down list. Why?

  • Why should I avoid using TIBTable?

  • I can't see updates made by other users. Why?

  • Why do my datasets close when I call Commit or Rollback?

  • When using Cached Updates with a Master/Detail relation, details disappear when I Post. What gives?

Where can I download latest version of IBX?

Always from CodeCentral.

Top

How does Refresh work in IBX?

Contrary to BDE's behavior, the Refresh method in IBX refreshes only the current record (where the dataset cursor is positionated) in order to minimize network traffic. If you want to refresh more than one record, close and re-open the dataset.

Top

How does RecordCount work in IBX?

Recordcount returns the number of fetched records. Because IBX only fetches new records when something actually asks for the next record, after opening a dataset RecordCount will return 0 if the dataset is empty and 1 if it is not. After a FetchAll (not an advisable practice), RecordCount will return the total number of records in the dataset.

In IBX, RecordCount should never be used to rely on how many records exist since it is only reliable for Paradox and DBase. If you really need to know the number of records in a dataset, issuing a "SELECT COUNT(*)" in a separate TIBSQL does the trick in most cases without the overhead of a FetchAll.

Top

When connecting a DBLookUpComboBox to a TIBQuery, I see just one record in the drop down list. Why?

Again, IBX only fetches records when something actually asks for the next record. In the case of the DBLookupCombo, it is incorrectly relying on the RecordCount (see previous question) to scale the drop down area before trying to fill the drop down list.

To solve it, just do the following in the combo's AfterOpen event (to force the fetching of at least a handful of records; this will increase the value of RecordCount):

With (Sender as TDataset) do begin
       MoveBy(MyDBLookupCombo.DropDownCount);
      First;
end;

Top

Why should I avoid using TIBTable?

Short answer: TIBTable is not C/S friendly, it is included in IBX for compatibility reasons only. TIBDataSet is the direct replacement.

Not-so-short answer: The Table Paradigm comes from file based databases like Paradox.  Basically no matter where the table is located all the rows and all the columns (and usually all the index information) is brought locally so the SQL engine (like the BDE) can work
with the data.  Since all the data must be retrieved locally anyways the TTable
was designed to work better in that environment.

The C/S Paradigm says that you let the server do the work of selecting what data
you need and you return only that which the user needs.  IOW you may only return
3 of the 5 columns or only 100 of the 1,000,000 rows etc.  The Table paradigm
tends to flood the network and does not scale well at all in the C/S world.

TIBDataset you just fill out the SelectSQL for what data needs to be retrieved
and the right click on it and select the DataSet Editor to let it help you
determine the InsertSQL, ModifySQL, DeleteSQL and RefreshSQL.  Once those are
filled out you have a fully updatable result set.  And it will be less expensive
in terms of speed, network traffic and memory than a table based paradigm.

Top

I can't see updates made by other users. Why?

First, check if your transaction isolation mode is Read Committed. If it's Snapshot (the Interbase default), you'll always get a consistent view of the data -- i.e., you won't see changes made by other users. Hint: To change the transaction isolation mode to Read Committed, double-click on your TIBTransaction component.

Next, make sure your application actually commits a transaction after any updates, either by using CommitRetaining or Commit.

Finally, if your dataset is already open on your PC when another user performs some updates, you will see those changes only after you close and re-open the dataset, or after you call the Refresh method and the updated record is the current record you are viewing.

Top

Why do my datasets close when I call Commit or Rollback?

Short answer: That's normal IBX behavior. Use CommitRetaining or RollbackRetaining to keep your datasets open.

Not-so-short-answer: In IBX, if you call Commit or Rollback this brings to an end the existence of a transaction handle on the client. As a result, all things that depend upon that transaction need to be rectified or they will become invalid. Without a transaction, InterBase doesn't know which versions of the records you should see -- i.e., it doesn't know whether your isolation mode should be ReadCommitted or Snapshot.

There are essentially two things that depend on a transaction. 1) Any changes that have been posted to the server and 2) any currently open "cursors".

A cursor in InterBase is what you get after executing a select statement with multiple records to return. You interact with the cursor by requesting fetches until that cursor is exhausted. All open cursors are dependant upon a transaction handle being present and if that transaction is ended the cursor will become invalid.

So, what IBX does when you call Commit or Rollback is to close all of your open datasets in order to avoid getting an invalid cursor error. This is because with IBX there isn't a layer that provides isolation between having datasets opened and ending transactions as the BDE and IBO do.

If you want to keep your datasets open, it is recommended that you use CommitRetaining or RollbackRetaining for processing your logical units of work (changes) to avoid datasets closing and that you reserve the usage of Commit and Rollback for when you want to free up the server so it can do its garbage collection, etc. You should do a "hard" Commit or Rollback as frequently as possible, though.

Top

When using Cached Updates with a Master/Detail relation, details disappear when I post. What gives?

This behavior is up at the TDataset level. When you go into Edit mode (or when
you ApplyUpdates) the DataLink is passed a message that the cursor has been
repositioned. This message will cause detail queries to close and re-open on the
"new" position. The only way to stop this is to break the DataLink. Set the detail's DataSource to nil before applying the master's update.

Top

你可能感兴趣的:(Technology)