您现在的位置:软界网技术中心软件开发VB/VB.NET > 技术显示
ADO 在informix的 Addnew
2000-7-25 0:00:00   网友评论       阅读次数 点此评论
   

ADO在informix的Addnew来源:cww
  在RDO时,我曾指出当Resultset.Addnew之後,目前的Resultset不会包含现在新增的这一笔,这是一个比较不好的现象(这在SQL SERVER中不会),试想,如果我们在Table中使用Serial型态的栏位(该Field的值会在每新增一笔资料时自动加一),而我们拿这个栏位的值当作流水来使用,而我们使用.AddNew之後,却因为Resultset没有包含该笔资料,所以我们就没有办法得知该Serial栏位的值。这时可能得产生一个unique的Key,而後再由资料库中取得该笔Record。

  但在ADO中,出乎意料之外的,它维护得不错,在AddNew之後,Current Record会停在Addnew的那一笔,而不是Addnew前的那一笔,这表示该笔资料已在Resultset之中了!不过如果要使用Serial的栏位,还得在AddNew之後再下一个Resync的Method把值传回来,这个原因在於,我们Informix使用的Cursor是在Client端(我上一篇文章中有说过,OpenLink的Multi-Tier ODBC Driver for Informix7.2,使用Server端的Cursor会有问题),而Serical栏位的值是Informix Server给的,所以在Update之後Serial栏位的值必定要由Server中再取出才知道,因此使用Resync方法来做。不过这里仍有一件事要提出,如果有Transaction的情况之下,.AddNew / .Update之後,如果Rollback,该笔Data仍会在Client端存在,而且也会占用Serical栏位的一个号码,这也还好啦,只要知道这个情况我们程式设计时注意一下便好了。  

Option ExplicitDim WithEvents cn As ADODB.ConnectionPrivate WithEvents rs As ADODB.RecordsetPrivate qry As ADODB.CommandPrivate adoerr As ADODB.ErrorsPrivate Sub Command2_Click()rs.AddNewrs!case_no = '1105'rs!fld2 = 'v'rs.Updaters.Resync adAffectCurrent 如果该Resultset中有Serical栏位, 目的在取得Serical的栏位的值rs.MoveFirstDo While Not rs.EOF Debug.Print rs!case_no, rs!myseri rs.MoveNextLoopEnd SubPrivate Sub Form_Load()Dim connstr As StringDim ans As Integer, errstr As String, sql As StringSet cn = New ADODB.Connectionconnstr = 'UID=cww;PWD=jjh5612;Database=cwwpf@eis;' _ + 'Driver={OpenLink Generic 32 Bit Driver};' _ + 'Host=192.168.0.61;' _ + ';FetchBufferSize=30' _ + ';NoLoginBox=Yes' _ + ';Options=' _ +   Protocol=TCP/IP' _ + ';ReadOnly=No' _ + ';ServerOptions=' _ + ';ServerType=Informix 7.2'cn.ConnectionString = connstrcn.Opensql = 'Select * from testab2 order by case_no'Set rs = New ADODB.RecordsetSet rs.ActiveConnection = cnrs.CursorLocation = adUseClientrs.Source = sqlrs.CacheSize = 30rs.Open , cn, adOpenKeyset, adLockOptimistic, adCmdTextEnd Sub
 
      来源: 作者:
 
【评论查看】