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与 ...
随机推荐
- Ajax异步调用Controller的Return JsonResult生成下拉列表
@using System.Web.Optimization; @{ Layout = null; } <!DOCTYPE html> <html> <head> ...
- DOM技术实现竞赛题页面
DOM技术实现竞赛题页面 这一段时间学习了DOM操作和JS开发,我就自己开发一个竞赛题的页面. 一.业务需求 1.目标:做一个一百道选择题的页面 2.功能: 显示题目和选项. 下一题上一题的按钮,到第 ...
- iOS CGContextRef画图时的常用方法
UIView的drawRect方法 CoreGraphics绘图 综述:描述系统会调用UIView的drawRect方法,所以coreGraphics的所有实现代码放在该函数内,setNeedsDis ...
- json中$ref对象重复引用问题
FastJson提供了SerializerFeature.DisableCircularReferenceDetect这个序列化选项,用来关闭引用检测.关闭引用检测后,重复引用对象时就不会被$ref代 ...
- Linux tcpdump 详解
简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具. tcpdump可以将网络中传送的数据包的 ...
- sphinx教程
http://www.php100.com/html/it/focus/2013/0916/6188.html### 以上一篇的email数据表为例: 数据结构: 01.CREATE TABLE em ...
- MySql如何编写高效的SQL
最近应团队要求,研究整理了下,mysql相关的优化,有些是根据实际java项目中碰到的情况经验之谈.欢迎讨论~ SQL 语言是一种强大而且灵活的语言,在使用 SQL 语言来执行某个关系查询的时候,用户 ...
- Android性能优化典范第一季
2015年伊始,Google发布了关于Android性能优化典范的专题,一共16个短视频,每个3-5分钟,帮助开发者创建更快更优秀的Android App.课程专题不仅仅介绍了Android系统中有关 ...
- wireshark长时间抓包分多个文件
前言 说一说这个问题的由来,一般使用wireshark不需要长时间抓包的,但是有时候遇到网络通信中非常棘手的问题,例如一个小时出现一次或者几个小时出现一次问题的情况,这种情况下就必须长时间抓包了.但是 ...
- Redis 发布订阅
订阅: class Program { //版本2:使用Redis的客户端管理器(对象池) public static IRedisClientsManager redisClientManager ...