当前位置: 首页 > 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.yayakq.cn/news/3449/

相关文章:

  • 网站开发商城酒类网站该怎么做
  • 网站平台建设成本网络有哪些广告推广方式
  • 视频网站怎么做外链网络舆情应对措施
  • 网站实时推送怎么做wordpress 后台登录慢
  • 500亿网站建设wordpress 买主题
  • 长清网站建设电话海南城乡建设庁网站
  • 国外网站做acm题目比较好陕西响应式网站建设公司
  • 有没有专门找装修公司的网站中国搜索提交网站
  • 广东恒力建设工程有限公司网站互联网产品推广案例范文
  • 网站后台程序开发wordpress语言插件qx
  • 合肥网站建设设计公司江苏国泰做的网站案例
  • 改行做网站怎样用8uftp做网站
  • 如何编程制作自己的网站一个小胖子从网站做任务的网站故事
  • 大潮建设集团有限公司 网站北京网页设计公司兴田德润怎么样
  • 云南热搜科技做网站不给源码dz论坛seo
  • 承德优化网站建设wordpress能生成静态文件下载
  • 国内阿里巴巴网站怎么做西宁做网站君博先进
  • 做网站UI说不会写文案wordpress 删除修订版本
  • 企业营销型网站建设荆门做网站公司
  • 自建站模板网站行业
  • 自己的网站怎么做seo阿里云上的网站空间好用吗
  • 专业的家居行业网站模板网站建设百度小程序
  • 做网站guangxiyandawordpress英文企业模板下载地址
  • 网站设计与建设实践五大搜索引擎 三大门户网站
  • 网站建设期任务及总结营销单页网站制作
  • 网站建设策划书事物选题石家庄做网站设计
  • 网站设计师介绍凡客诚品app下载
  • 外国s网站建设广州最新新闻事件今天
  • 个人网站的订单网站建设中 页面
  • 商城网站开发培训学校网站建设学生兼职