Cocos2d-x 3.2 学习笔记(十五)保卫萝卜 场景与数据


下载网址:http://www.sqlite.org/download.html。



#ifndef __DBUtil__
#define __DBUtil__
#include <string>
#include "cocos2d.h"
#include "sqlite3.h" using namespace std;
USING_NS_CC;
class DBUtil{
public: /************************************************************
封装 sqlite3操作
************************************************************/
//用来创建一个db数据库 db为数据库的名字
// 打开数据库
static void initDB(const char *url); //用来判断表格是否存在
// name:表示表名
static bool tableIsExist(string table_name); //用来创建一个表名为name的表格,创建时会先匹配时否有该表的存在如果存在则不创建
//创建表
static void createTable(string sql,string table_name); //用来删除一张表名为name的表格,删除时会先匹配是否有该表的存在如果不存在则不执行删除操作
//删除表名
static void deleteTable(string sql,string table_name); //用来向表中插入一条数据
//插入一条数据
static void insertData(string sql); //用来向表中删除一条数据
//删除一条数据
static void deleteData(string sql); //用来向表中修改一条数据
// 修改一条数据
static void updateData(string sql); //获取表的全部数据
// 返回记录的条数
static int getAllData(string table_name,std::function<void(std::map<string,string>)> callback); //读取一条记录的信息
/*
* 此方法是查询方法,pSender()
*/
static void getDataInfo(string sql,std::function<void(std::map<string,string>)> callback); //关闭打开的数据库
static void closeDB();
}; #endif
DBUtil.h
#include "DBUtil.h" sqlite3 *pDB = NULL;//数据库指针
char * errMsg = NULL;//错误信息
std::string sqlstr;//SQL指令
int result;//sqlite3_exec返回值
unsigned int _count=;
std::map<unsigned int,std::function<void(std::map<string,string>)>> _keyMap; void DBUtil::initDB(const char *db)
{
//打开一个数据库,如果该数据库不存在,则创建一个数据库文件
result = sqlite3_open(db, &pDB);
if( result != SQLITE_OK )
log( "打开数据库失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //tableIsExist的回调函数
int isExisted( void * para, int n_column, char ** column_value, char ** column_name )
{
bool *isExisted_=(bool*)para;
*isExisted_=(**column_value)!='';
return ;
} bool DBUtil::tableIsExist( string table_name )
{
if (pDB!=NULL)
{
//判断表是否存在
bool tableIsExisted;
sqlstr = "select count(type) from sqlite_master where type='table' and name ='"+table_name+"'";
result =sqlite3_exec(pDB,sqlstr.c_str(),isExisted,&tableIsExisted,&errMsg);
return tableIsExisted;
}
return false;
} void DBUtil::createTable( string sql,string table_name )
{
if (!tableIsExist(table_name))
{
//创建表,设置ID为主键,且自动增加
result = sqlite3_exec(pDB,sql.c_str(),NULL,NULL,&errMsg);
if( result != SQLITE_OK )
log( "创建表失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} } void DBUtil::deleteTable( string sql,string table_name )
{
if (tableIsExist(table_name))
{
result = sqlite3_exec(pDB,sql.c_str(),NULL,NULL,&errMsg);
if( result != SQLITE_OK )
log( "创建表失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
}
} //@示例语句sqlstr=" insert into MyTable_1( name ) values ( 'data',..... ) ";
void DBUtil::insertData( string sql ){
result = sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //@示例语句sqlstr="delete from MyTable_1 where ID = 2";
void DBUtil::deleteData( string sql )
{
result=sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //@示例语句 sqlstr="update MyTable_1 set name='data' where ID = 3";
void DBUtil::updateData( string sql )
{
result = sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //getDataCount的回调函数
int loadRecordCount( void *para, int n_column, char ** column_value, char ** column_name )
{
std::map<string,string> data;
int index;
for( index = ; index < n_column; index ++ )
{
data.insert(std::pair<string,string>( column_name[index], column_value[index] ));
}
auto num = *(unsigned int *)para;
auto callback = _keyMap.at(num);
if( callback != nullptr )
{
callback(data);
}
return ;
} int DBUtil::getAllData(string table_name,std::function<void(std::map<string,string>)> callback)
{
string sql = "select * from "+table_name;
_count++;
_keyMap.insert(std::pair<unsigned int,std::function<void(std::map<string,string>)>>(_count,callback));
int count=sqlite3_exec( pDB, sql.c_str() , loadRecordCount, &_count, &errMsg );
return count;
} //getDataInfo的回调函数
int loadRecord( void * para, int n_column, char ** column_value, char ** column_name )
{
std::map<string,string> data;
int index;
for( index = ; index < n_column; index ++ )
{
string str1 = column_name[index];
if( column_value[index] == NULL )
{
log("DBUtil Get Data Value Failure! Table Name Is '%s'",str1.c_str());
continue;
}
string str2 = column_value[index];
data.insert(std::pair<string,string>(str1,str2));
}
auto num = *(unsigned int *)para;
auto callback = _keyMap.at(num);
if( callback != nullptr )
{
_keyMap.erase(num);
callback(data);
}
return ;
} void DBUtil::getDataInfo( string sql,std::function<void(std::map<string,string>)> callback )
{
_count++;
_keyMap.insert(std::pair<unsigned int,std::function<void(std::map<string,string>)>>(_count,callback));
sqlite3_exec( pDB, sql.c_str() , loadRecord, &_count, &errMsg );
} void DBUtil::closeDB()
{
sqlite3_close(pDB);
}
DBUtil.cpp

Cocos2d-x 3.2 学习笔记(十五)保卫萝卜 场景与数据的更多相关文章
- python3.4学习笔记(十五) 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)
python3.4学习笔记(十五) 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) python print 不换行(在后面加上,end=''),prin ...
- (转载)西门子PLC学习笔记十五-(数据块及数据访问方式)
一.数据块 数据块是在S7 CPU的存储器中定义的,用户可以定义多了数据块,但是CPU对数据块数量及数据总量是有限制的. 数据块与临时数据不同,当逻辑块执行结束或数据块关闭,数据块中的数据是会保留住的 ...
- (C/C++学习笔记) 十五. 构造数据类型
十五. 构造数据类型 ● 构造数据类型概念 Structured data types 构造数据类型 结构体(structure), 联合体/共用体 (union), 枚举类型(enumeration ...
- MySQL学习笔记十五:优化(2)
一.数据库性能评测关键指标 1.IOPS:每秒处理的IO请求次数,这跟磁盘硬件相关,DBA不能左右,但推荐使用SSD. 2.QPS:每秒查询次数,可以使用show status或mysqladmin ...
- Java基础学习笔记十五 集合、迭代器、泛型
Collection 集合,集合是java中提供的一种容器,可以用来存储多个数据. 在前面的学习中,我们知道数据多了,可以使用数组存放或者使用ArrayList集合进行存放数据.那么,集合和数组既然都 ...
- angular学习笔记(十五)-module里的'服务'
本篇介绍angular中的模块:module 在笔记(二)http://www.cnblogs.com/liulangmao/p/3711047.html里已经讲到过模块,这篇主要讲模块的 '服务' ...
- Java学习笔记十五:Java中的成员变量和局部变量
Java中的成员变量和局部变量 一:成员变量: 成员变量在类中定义,用来描述对象将要有什么 成员变量可以被本类的方法使用,也可以被其他类的方法使用,成员变量的作用域在整个类内部都是可见的 二:局部变量 ...
- MYSQL进阶学习笔记十五:MySQL 的账号权限赋予!(视频序号:进阶_33,34)
知识点十六:MySQL的账号权限赋予(33) 一.MySQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你全力以内的事情,不可以越界.比如只允许你执行select操作,那么你就不能执 ...
- 数据结构和算法学习笔记十五:多路查找树(B树)
一.概念 1.多路查找树(multi-way search tree):所谓多路,即是指每个节点中存储的数据可以是多个,每个节点的子节点数也可以多于两个.使用多路查找树的意义在于有效降低树的深度,从而 ...
- JavaScript权威设计--JavaScript脚本化文档Document与CSS(简要学习笔记十五)
1.Document与Element和TEXT是Node的子类. Document:树形的根部节点 Element:HTML元素的节点 TEXT:文本节点 >>HtmlElement与 ...
随机推荐
- 8.4.1 ImageLoader
ImageLoader 的工作原理(已经不维护了) 在显示图片的时候,它会先在内存中查找:如果没有,就去本地查找:如果还没有,就开一个新的线程去下载这张图片,下载成功会把图片同时缓存到内存和本地. 基 ...
- 测试架构图 High Level 产品技术(无事来更新,证明这个博客还是Live的)
一个完整的产品测试所需要掌握的产品技术架构. 1.最底层硬件平台(服务器与存储) 对于一个大型商业解决方案来说,性能与可靠性是非常重要的要求,那么服务器与存储就是专门来满足需求的. 服务器: 服务器端 ...
- windows编程:画线,简单的碰撞检测,简单的帧率锁定
#define WIN32_LEAN_AND_MEAN #include <windows.h> #include <windowsx.h> #include <mmsy ...
- nginx日志格式来分析网站访问速度与瓶颈
参考地址:http://www.ttlsa.com/nginx/nginx-modules-ngx_http_log_request_speed/ 查看nginx 安装模块和配置 /usr/local ...
- STL练习题续
//zjnu 1399 //sort 数组可用//vector sort(vector) #include<iostream> #include<algorithm> usin ...
- \(\S1 \) Gaussian Measure and Hermite Polynomials
Define on \(\mathbb{R}^d\) the normalized Gaussian measure\[ d \gamma(x)=\frac{1}{(2\pi)^{\frac{d}{2 ...
- Android前端人员与后台开发的撕逼(一)
首先表明一下身份,本人是Android前端开发人员,本篇只做合理性探讨,不进行人身攻击: 其次希望各位大神进行点评!点评!点评! 我们讨论一下接口的两种返回方式,直接举例说明一下,假设书籍信息表有30 ...
- Restful.Data v1.0 - 轻量级数据持久层组件, 正式开源发布了
经过几个星期的优化调整,今天 Restful.Data 正式开源发布. 源码地址:https://github.com/linli8/Restful 今天不写那么多废话了,还是重新介绍一下 Restf ...
- 我的ORM之十一 -- 缓存
我的ORM索引 对某一个查询频繁重复,应该使用缓存. 缓存应该是可以配置. 配置 Web.config: <configuration> <configSections> &l ...
- JavaScript思维导图—数组
JavaScript思维导图-来自@王子墨http://julying.com/blog/the-features-of-javascript-language-summary-maps/