Get Oracle Sequence Value
The code assumes the Editor is in use, to determine the workspace of the sequence. Alternatively, the workspace could be derived from a feature class or table.
How to use:
- Paste the macro into VBA.
- Modify the code to point to the desired sequence and run the macro.
 Public Sub GetSequenceNumber()
Public Sub GetSequenceNumber() Dim pEditor As IEditor
  Dim pEditor As IEditor Dim pFeatWorkspace As IFeatureWorkspace
  Dim pFeatWorkspace As IFeatureWorkspace Dim pQueryDef As IQueryDef
  Dim pQueryDef As IQueryDef Dim pCursor As ICursor
  Dim pCursor As ICursor Dim pRow As IRow
  Dim pRow As IRow 
   ' Find the workspace of the sequence
  ' Find the workspace of the sequence ' Assume we are in VBA and already editing
  ' Assume we are in VBA and already editing
 Dim pUID As New esriCore.UID
  Dim pUID As New esriCore.UID pUID = "esriCore.Editor"
  pUID = "esriCore.Editor" Set pEditor = Application.FindExtensionByCLSID(pUID)
  Set pEditor = Application.FindExtensionByCLSID(pUID) Set pFeatWorkspace = pEditor.EditWorkspace
  Set pFeatWorkspace = pEditor.EditWorkspace 
   ' Define the query
  ' Define the query Set pQueryDef = pFeatWorkspace.CreateQueryDef
  Set pQueryDef = pFeatWorkspace.CreateQueryDef pQueryDef.SubFields = "myowner.mysequence.NEXTVAL"
  pQueryDef.SubFields = "myowner.mysequence.NEXTVAL" 'if no 'sys', error message would raise to notice that no table was found
  'if no 'sys', error message would raise to notice that no table was found pQueryDef.Tables = "sys.dual"
  pQueryDef.Tables = "sys.dual" Set pCursor = pQueryDef.Evaluate
  Set pCursor = pQueryDef.Evaluate 
   'Get the sequence value from the returned row
  'Get the sequence value from the returned row
 Set pRow = pCursor.NextRow
  Set pRow = pCursor.NextRow MsgBox pRow.Value(0)
  MsgBox pRow.Value(0) End Sub
End Sub

----------------------------------------------------------- 
佛对我说:你心里有尘。我用力的拭擦。
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号