当前位置: 首页 > news >正文

网站建设规划书河北互联网平台有哪些

网站建设规划书河北,互联网平台有哪些,青岛 建网站,设计公司调研报告语法 BEGIN TRANSACTION; COMMIT TRANSACTION; #xff08;或END TRANSACTION;#xff09; ROLLBACK TRANSACTION; 事务处理 除了一些PRAGMA语句以外#xff0c;其它访问数据库的语句会自动启动事务处理#xff0c;并且在结束时自动提交。 通过上一节的命令可以手动控制…语法 BEGIN TRANSACTION; COMMIT TRANSACTION; 或END TRANSACTION; ROLLBACK TRANSACTION; 事务处理 除了一些PRAGMA语句以外其它访问数据库的语句会自动启动事务处理并且在结束时自动提交。 通过上一节的命令可以手动控制事务处理过程。 如果在事务期间关闭了数据库或者发生了错误并且通过ON CONFLICT指定了冲突处理算法则会自动回滚事务。 事务控制语句不能嵌套执行可以通过SAVEPOINT和RELEASE命令模拟嵌套行为。 通过SAVEPOINT在事务中创建保存点回滚时指定保存点名称可回滚到指定位置之前的处理将保存。 读事务和写事务 SQLite支持多个数据库在不同线程或进程同时读但只支持一个写事务存在。 读事务只能读数据写事务可以读也可以写。通过SELECT可以启动一个读事务CREATEDELETEDROP和UPDATE启动写事务。在一个读事务期间如果出现写操作事务会升级为写事务。但如果此时有另一个数据库连接正在处理写事务上一个写操作就会失败并报告SQLITE_BUSY错误。 当一个读事务活动时另一个连接对相同表的写操作不会反馈到读事务中也就是说不会读到写操作刚刚写入的数据。 DEFERRED, IMMEDIATE和EXCLUSIVE事务 DEFERRED是默认行为表示在访问数据库之前事务并未真正启动仅仅是设置一个标记告诉数据库关闭自动提交功能。事务会在显式调用COMMIT或ROLLBACK或发生错误时自动回滚执行以重新启用自动提交操作。 DEFERRED启动后如果第一个语句时SELECT则启动一个读事务。后续出现写操作时自动升级为写事务。 IMMEDIATE语句则是告诉数据库立即启动一个写事务并不会通过下一条语句是读还是写来确定事务类型。如果此时另一个连接已启动了一个写事务则该操作失败并报告SQLITE_BUSY错误。 EXCLUSIVE与IMMEDIATE类似在WAL mode格式下是完全相同的但在其它日志模式下该语句会阻止其它连接读取数据库。 隐式事务和显式事务 隐式事务不是通过BEGIN启动的事务在语句完成后自动提交事务。当一条语句reset或finalized时其打开的游标自动关闭标识着语句完成。有些语句可能因为事务控制原因在reset或finalized之前完成但这一行为无法保证所以不要假定在reset或finalized之前语句已结束。可以保证的是调用sqlite3_reset或sqlite3_finalize之后语句一定是完成状态。sqlite3_blob在启动增加BLOB读写期间只有在明确关闭blob时才表示语句完成。 COMMIT命令会立即执行提交操作即便有SELECT语句尚未完成也没关系但如果有写操作未完成则会报SQLITE_BUSY错误。 这应该是发生在事务有多线程处理的情况。 如果有另一个线程或进程有读操作COMMIT操作可能报告SQLITE_BUSY错误此时可以等待那个读操作完成后再次尝试COMMIT。 早期版本中(3.7.11之前ROLLBACK可能因存在未完成的查询操作而报告SQLITE_BUSY错误。之后的版本遇到这一行为时不会报错但会撤销未完成的查询操作并导致那些操作返回SQLITE_ABORT错误或SQLITE_ABORT_ROLLBACK错误。在3.8.8及之后的版本中只要回滚操作不修改表结构未完成的读操作将继续处理而不受ROLLBACK影响。 如果PRAGMA_journal_mode设置为OFF关闭回滚日志ROLLBACK的行为不确定。 事务出错处理 有些错误不会导致事务回滚以下错误会导致自动回滚 SQLITE_FULL: 磁盘空间不足SQLITE_IOERR: 磁盘IO错误SQLITE_BUSY: 数据库正在被其它进程使用SQLITE_NOMEM: 内存不足 对于这些错误SQLite尝试回滚刚才发生错误的操作而事务内之前完成的操作则保持不变并且继续执行事务内的其它操作。但是通常我们会希望回滚事务内的所有操作以确保数据的一致性通过C语言接口sqlite3_get_autocommit可以检查SQLite是采取了单个回滚还是全部回滚行为。 建议在应用程序内拦截这些错误以显式调用ROLLBACK命令回滚整个事务。如果SQLite本身已回滚了下个事务再调用ROLLBACK会报错但这个错误无关紧要可以忽略。 后期版本可能会增加其它导致事务自动回滚的错误清单也可能改变对不同错误的回滚行为特别是针对这些错误简化回滚行为。 原文链接https://www.sqlite.org/lang_transaction.html
http://wiki.neutronadmin.com/news/244360/

相关文章:

  • 门户网站建设不断多用户商城思维导图
  • 东明县住房和城乡建设局网站广告网名
  • 淄博网站制作优化海南营业执照网上怎么申请
  • 润滑油手机网站模板网站建设费归入长期待摊费用
  • 成都成华区网站建设如何判断网站有cdn加速
  • 网站没有备案会怎么样专业微信网站建设价格
  • 电脑培训学校学费多少长沙正规关键词优化价格从优
  • 网站后台管理员密码淮北论坛人才招聘网
  • 响应式网站建站工具江门网站建设 卓华
  • 网站建设方案云盘app开发商业计划书模板
  • 东莞设计网站建设html标签属性
  • 美工做任务网站怎么查网站的空间商
  • 在哪学习建网站wordpress设置下载链接
  • 网站不备案违法吗网站建设加优化
  • 仁寿建设局网站网站优化解决方案
  • 河南旅游网站建设建网站和开发软件哪个难
  • 网站建设认知与理解VPS如何做镜像网站
  • php网站设计要学多久做网站阜阳
  • 深圳免费网站制作哪个好网站空间虚拟主机续费
  • 建筑业招聘网站永久免费进销存管理软件手机版
  • 做电子商务网站建设工资多少公司网站上传文章
  • 网站开发php工程师工业智能科技网站设计
  • 宁夏小蚁人网站建设哈尔滨网站排名公司
  • 徐州网站制作费用地方门户网站模板
  • 郑州网站seo优化建设网站的公司的官网
  • 建设网站什么语言维护官网
  • 我做外贸要开国际网站吗网站建立的方式是什么
  • 网站直播怎么做的徐州编程培训机构
  • 生活信息网站建设手机网站注册
  • 太仓网站建设网站推广WordPress链接点击次数统计