VB.NET使用OracleTransaction对象深入剖析
创始人
2024-06-08 15:21:30
0

VB.NET还是比较常用的,于是我研究了一下VB.NET使用OracleTransaction对象,在这里拿出来和大家分享一下,希望对大家有用。

VB.NET使用OracleTransaction对象需要注意的几点:

1)你需要在你整个事务执行中只能有***OracleConnection,也就是说如果你事务处理过程中如果需要与数据库的操作都只能在这***的Command中执行,类似于:

  1. imgCommand.CommandText = sSQL 
  2. imgCommand.ExecuteNonQuery()或其他操作 

若你新建一个连接执行其他数据库操作的话,整个事务过程就会抛出异常

2)如果你需要在你SQL语句中加入参数,则你必须在你执行完提交或相关数据库操作之后将其Command的参数清空,下边举一个实际的项目里的事务函数:

  1. '''  
  2. ''' 保存热点文本文件信息到数据库  
  3. ''' 
  4.  
  5. Private Function SaveTextFile()Function SaveTextFile() As Boolean  
  6. Dim sSQl As String  
  7. sSQl = "select type_id from sys_file_type where file_extname='TXT'" 
  8. Try  
  9. imgCommand.CommandText = sSQl 
  10. Dim typeID As Int32 = Convert.ToInt32(imgCommand.ExecuteScalar()) '文件类型  
  11. '读取文本信息  
  12. Dim Textblob() As Byte = GetText()  
  13.  
  14. sSQl = "insert into t_watch_textcontent(image_id,text_content,type_id) 
    values(:imageid,:textcontent,:typeid)"
     
  15. '增添SQL参数  
  16. Dim Param As OracleClient.OracleParameter  
  17. Param = New OracleClient.OracleParameter("imageid", sNewImageID)  
  18. imgCommand.Parameters.Add(Param)  
  19. Param = New OracleClient.OracleParameter("textcontent", Textblob)  
  20. imgCommand.Parameters.Add(Param)  
  21. Param = New OracleClient.OracleParameter("typeid", typeID)  
  22. imgCommand.Parameters.Add(Param)  
  23.  
  24. '提交信息  
  25. imgCommand.CommandText = sSQl 
  26. If imgCommand.ExecuteNonQuery() > 0 Then  
  27. bResult = True 
  28. '关键是这里,需要你手动清除参数  
  29. imgCommand.Parameters.Clear()  
  30. End If  
  31. Catch ex As Exception  
  32. Me.ExceptionMessage = ex 
  33. bResult = False 
  34. End Try  
  35.  
  36. Return bResult  
  37. End Function 

以上介绍VB.NET使用OracleTransaction对象。

【编辑推荐】

  1. 浅谈VB.NET线程构造器
  2. 简单分析VB.NET使用线程
  3. VB.NET List(T)编写框架方法
  4. 简单介绍VB.NET线程同步
  5. VB.NET声明API详细描述

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...