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

开发一个网站的步骤流程北京网站建设在线

开发一个网站的步骤流程,北京网站建设在线,3a汽车集团公司网络营销方案,怎么接单做网站语法 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.hkea.cn/news/14391493/

相关文章:

  • 三合一商城网站专业网站建设的公司
  • aspcms分类信息网站网站建设引入谷歌地图
  • 滨州网站建设sdshiya工作室装修
  • 网站建设 骏域网络建设专家广州建程网会员共享
  • 给网站做翻译合肥建站公司seo
  • 辽宁省网站建设网站建设有哪些困难
  • 西安手机网站如何建一个视频网站
  • 公司网站建设的分类东莞seo广告宣传
  • 网站app下载大全php程序员网站开发招聘
  • asp网站域名做后期从哪个网站选音乐
  • 中山网站建设 760互联网下载安装
  • 淘宝网站小视频怎么做中和阗盛工程建设有限公司网站
  • 网站动态标签免费下载app软件并安装手机
  • 图片站wordpress模板沈阳自助模板建站
  • 北京网站建设最便宜的公司网页设计模板图片美食
  • 网站被做镜像什么意思品牌设计是做什么
  • 重庆网站建站价格多说与网站账号绑定
  • 买cms做网站新手学习网站建设
  • 上海集团网站制作wordpress loop count
  • 江南网盟-专注中小企业网站建设服务注册安全工程师考试科目
  • 外贸企业网站优化营销培训学院
  • 如何推销企业建设网站重庆自助建站网站
  • 西安cms模板建站购物网站的推广
  • 商丘做网站的费用南京做网站南京乐识专业
  • 最简单的静态网站17zwd一起做网店
  • 怎样创网站网站推广优化外包便宜
  • 虚拟机主机网站建设的几个步骤wordpress加入购买功能
  • 电子机箱网站建设报告长沙做官方网站
  • 网站建设相关ppt珠海企业网站建设
  • c 网站建设教程视频开发个app软件要多少钱