VisualC++ADO数据库编程入门(5)
来源:优易学  2010-1-14 18:52:11   【优易学:中国教育考试门户网】   资料下载   IT书店

 

  说明:Optimize属性是由Provider提供的属性(在ADO中称为动态属性),ADO本身没有此属性。

  (2)、排序

  要排序也很简单,只要把要排序的关键字列表设置到Recordset对象的Sort属性里即可,例如:

  pRstAuthors->CursorLocation = adUseClient;

  pRstAuthors->Open("SELECT * FROM mytable", _variant_t((IDispatch *) pConnection), adOpenStatic, adLockReadOnly, adCmdText); ...... pRst->Sort = "姓名 DESC, 年龄 ASC";

  关键字(即字段名)之间用逗号隔开,如果要以某关键字降序排序,则应在该关键字后加一空格,再加DESC(如上例)。升序时ASC加不加无所谓。本操作是利用索引进行的,并未进行物理排序,所以效率较高。

  但要注意,在打开记录集之前必须将记录集的CursorLocation属性设置为adUseClient,如上例所示。Sort属性值在需要时随时可以修改。

  4、事务处理

  ADO中的事务处理也很简单,只需分别在适当的位置调用Connection对象的三个方法即可,这三个方法是:

  (1)、在事务开始时调用

  pCnn->BeginTrans();

  (2)、在事务结束并成功时调用

  pCnn->CommitTrans ();

  (3)、在事务结束并失败时调用

  pCnn->RollbackTrans ();

  在使用事务处理时,应尽量减小事务的范围,即减小从事务开始到结束(提交或回滚)之间的时间间隔,以便提高系统效率。需要时也可在调用 BeginTrans()方法之前,先设置Connection对象的IsolationLevel属性值,详细内容参见MSDN中有关ADO的技术资料。

  使用ADO编程常见问题解答

  以下均是针对MS SQL 7.0编程时所遇问题进行讨论。

  1、连接失败可能原因

  Enterprise Managemer内,打开将服务器的属性对话框,在Security选项卡中,有一个选项Authentication。

  如果该选项是Windows NT only,则你的程序所用的连接字符串就一定要包含Trusted_Connection参数,并且其值必须为yes,如:

  "Provider=SQLOLEDB;Server=888;Trusted_Connection=yes"

  ";Database=master;uid=lad;";

  如果不按上述操作,程序运行时连接必然失败。

上一页  [1] [2] [3] [4] 下一页

责任编辑:cyth

文章搜索:
 相关文章
热点资讯
资讯快报
热门课程培训