SQLite学习笔记(十)-- 事务基本概念和代码实现(C++实现)

1.事务基本概念

  • 什么是事务?
    事务是用户定义的一些列数据操作,这些操作是一个完整的不可分的工作单元。一个事务要么全部执行,要么全部不执行。
  • 视图案例
    例如银行的转账操作,张三向李四转账1000元。该事务包含以下两个操作:
    1.张三账户上扣除1000元;
    2.李四账户上增加1000元。
    这两个操作就构成一个事务操作。两个操作要么全部执行,要么全部不执行。只执行任意一个,都会导致账户金额的混乱。
    该事务的具体代码见下文。
  • SQLite事务执行流程
    1.以begin语句开启一个事务;
    2.依次执行事务中的所有操作,并检查其是否执行成功;
    3.如果所有操作全部成功,则执行commit语句;否则执行rollback语句。

2.代码实例

  • 代码说明
    本例主要展示用事务模式来执行转账操作。
  • 测试平台
    1.开发语言:C++
    2.开发工具:VS2015
    3.操作系统:Win7 X64
  • 测试数据说明
    测试表为Account表,其结构如下:
    这里写图片描述
    测试表的内容如下:
    这里写图片描述

  • 具体代码

#include <iostream>
#include <Windows.h>
using namespace std;

//sqlite3头文件
#include "sqlite3.h"
//sqlite3库文件
#pragma comment(lib,"sqlite3.lib")

//函数功能:将utf8字符转gb2312字符
//参数:    const char* utf8[IN]                   -- UTF8字符
//返回值:  char*                                  -- gb2312字符
char* U2G(const char* utf8)
{
    int len = MultiByteToWideChar(CP_UTF8, 0, utf8, -1, NULL, 0);
    wchar_t* wstr = new wchar_t[len + 1];
    memset(wstr, 0, len + 1);
    MultiByteToWideChar(CP_UTF8, 0, utf8, -1, wstr, len);
    len = WideCharToMulti
  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值