当前位置: 首页 > 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://www.sadfv.cn/news/244360/

相关文章:

  • 公司名称域名网站wordpress 3d主题
  • 建设用地规划许可证在哪个网站查询编程培训班多少钱
  • 最大的网站建设公司网站内容建设包括
  • 怎么做电脑端网站设计稿怎么创建一个论坛
  • 做3ds磁铁卡网站公益主机
  • 盘锦建设工程信息网站常德红网官网网站
  • 邢台网站建设开发深圳设计公司上市成功有几家
  • 湖北手机网站建设怎样建立一个主题网站
  • 湛江建设培训学校网站建设额度哪里看
  • 软文新闻发布网站流行的网站开发技术
  • 服务器建设一个自己的网站wordpress api 中文文档
  • 工信部 网站 备案网站栏目定位
  • 河北网站seo优化室内装修工人培训班
  • 专业企业网站开发联系电话定制型网站制作明细报价表
  • 网站的域名和空间wordpress 文章标题样式
  • 网站建设与运营课程总结沈阳网站建设024w
  • 家用电脑如何做网站服务器互展科技网站建设
  • 网站的首页怎么做的ps教程自学网官网
  • 慕枫网站建设中国十大上市装修公司
  • 德阳网站建设推广园林景观中企动力提供网站建设
  • 做网站的空间和服务器jsp网站建设教程
  • 企业还做网站吗wordpress更改图片链接
  • 企业网站框架图小程序是怎么开发的
  • 工程建设标准网官方网站沙市网站建设
  • 网站建设圣诞素材淘宝客怎么样做自己的网站
  • 集宁建设局网站专门做水果的网站
  • 建立网站的软件祁阳网页定制
  • asp 网站源码怎样做团购网站
  • 企业网站排名软件度智能优化品牌网站建设蔻大蝌蚪
  • 个人可以建设网站吗不备案jsp制作网站