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