Cocos2d-x数据持久-变更数据

当数据变化,参与SQL报表insert、update和delete声明。这项3个月SQL语句可以带参数。

详细过程的数据,例如,下面的变化看出。
(1) 采用sqlite3_open开放式数据库功能。
(2) 使用sqlite3_prepare_v2函数预处理SQL语句。
(3) 使用sqlite3_bind_text函数绑定參数。
(4) 使用sqlite3_step函数运行SQL语句。
(5) 使用sqlite3_finalize和sqlite3_close函数释放资源。
这与查询数据少了提取字段数据这个步骤,其它步骤是一样的。以下我们看看代码部分。

1、插入备忘录

NoteDAO.cpp中的NoteDAO::create插入备忘录的代码例如以下:
int NoteDAO::create(string pDate, string pContent)
{
	//初始化数据库
	initDB();

	sqlite3* db= NULL;

	string path = dbDirectoryFile();

	if (sqlite3_open(path.c_str(), &db) != SQLITE_OK) {
		sqlite3_close(db);
		CCASSERT(false, "DB open failure.");
	} else {
		string sqlStr = "INSERT OR REPLACE INTO note (cdate, content) VALUES (?

,?)";		①
		sqlite3_stmt *statement;
		//预处理过程
		if (sqlite3_prepare_v2(db, sqlStr.c_str(), -1, &statement, NULL) == SQLITE_OK) {
			//绑定參数開始
			sqlite3_bind_text(statement, 1, pDate.c_str(), -1, NULL); 						②
			sqlite3_bind_text(statement, 2, pContent.c_str(), -1, NULL);

			//运行插入
			if (sqlite3_step(statement) != SQLITE_DONE) {							③
				CCASSERT(false, "Insert Data failure.");
			}
		}
		sqlite3_finalize(statement);
		sqlite3_close(db);
	}
	return 0;
}

上述代码第①行是插入数据的SQL语句,当中的问号(它是占位符)就是要绑定的參数。第②行代码sqlite3_bind_text(statement, 1, pDate.c_str(), -1, NULL)是绑定第一个參数。
第③行代码中的sqlite3_step(statement)语句运行插入语句,常量SQLITE_DONE表示运行完毕。
为了可以调用NoteDAO中插入备忘录函数create。我们须要在HelloWorldScene场景中调用。HelloWorldScene.cpp主要代码例如以下:

void HelloWorld::OnClickMenu2(cocos2d::Ref* pSender)
{
	string currentTime = MyUtility::getCurrentTime();
	log("%s",currentTime.c_str());
	NoteDAO::create(currentTime, "欢迎使用MyNote.");
}

HelloWorld::OnClickMenu2函数是玩家点击Insert Data菜单时候回调的函数。当中MyUtility::getCurrentTime()语句是获得当前时间。

提示  在Win32平台,採用Visual Studio 进行编译执行时候中文会有一些麻烦!我们须要将源码文件另存为Unicode(UTF-8无签名)格式。能够參考4.2.5一节解决方法,有的时候会有例如以下编译错误:error C2001: 常量中有换行符。我们须要在中文字符后面加入一些英文字符。或者“啊”等特殊的中文字符。

比如:"欢迎使用MyNote。"这个字符串后面是中文句号“。”结尾,编译的时候就会出现error C2001错误。本例中我们採用英文句号“.”结尾,编译就不会有错误,可是会有警告。

这样的问题仅仅会出如今Win32平台,其他平台没有问题。为了省事我们測试时候能够不採用中文字符。

2、删除备忘录
NoteDAO.cpp中的NoteDAO::remove删除备忘录的代码例如以下:
i

nt NoteDAO::remove(string pDate)
{
	//初始化数据库
	initDB();

	sqlite3* db= NULL;

	string path = dbDirectoryFile();

	if (sqlite3_open(path.c_str(), &db) != SQLITE_OK) {
		sqlite3_close(db);
		CCASSERT(false, "DB open failure.");
	} else {
		string sqlStr = "DELETE  from note where cdate =?";
		sqlite3_stmt *statement;
		//预处理过程
		if (sqlite3_prepare_v2(db, sqlStr.c_str(), -1, &statement, NULL) == SQLITE_OK) {
			//绑定參数開始
			sqlite3_bind_text(statement, 1, pDate.c_str(), -1, NULL);
			//运行删除
			if (sqlite3_step(statement) != SQLITE_DONE) {
				CCASSERT(false, "Delete Data failure.");
			}
		}
		sqlite3_finalize(statement);
		sqlite3_close(db);
	}
	return 0;
}

为了可以调用NoteDAO中删除备忘录函数remove。我们须要在HelloWorldScene场景中调用。

HelloWorldScene.cpp主要代码例如以下:

void HelloWorld::OnClickMenu3(cocos2d::Ref* pSender)
{
	NoteDAO::remove("2008-08-16 10:01:02");
}

HelloWorld::OnClickMenu3函数是玩家点击Delete Data菜单时候回调的函数。

3、改动备忘录
NoteDAO.cpp中的NoteDAO::modify改动备忘录的代码例如以下:

int NoteDAO::modify(string pDate, string pContent)
{
	//初始化数据库
	initDB();

	sqlite3* db= NULL;

	string path = dbDirectoryFile();

	if (sqlite3_open(path.c_str(), &db) != SQLITE_OK) {
		sqlite3_close(db);
		CCASSERT(false, "DB open failure.");
	} else {
		string sqlStr = "UPDATE note set content=?

where cdate =?";
		sqlite3_stmt *statement;
		//预处理过程
		if (sqlite3_prepare_v2(db, sqlStr.c_str(), -1, &statement, NULL) == SQLITE_OK) {
			//绑定參数開始
			sqlite3_bind_text(statement, 1, pContent.c_str(), -1, NULL);
			sqlite3_bind_text(statement, 2, pDate.c_str(), -1, NULL);

			//运行改动数据
			if (sqlite3_step(statement) != SQLITE_DONE) {
				CCASSERT(false, "Upate Data failure.");
			}
		}
		sqlite3_finalize(statement);
		sqlite3_close(db);
	}
	return 0;
}

为了可以调用NoteDAO中改动备忘录函数modify。我们须要在HelloWorldScene场景中调用。HelloWorldScene.cpp主要代码例如以下:

void HelloWorld::OnClickMenu4(cocos2d::Ref* pSender)
{
	NoteDAO::modify("2008-08-16 10:01:02", "改动数据。

");
}

HelloWorld::OnClickMenu4函数是玩家点击Update Data菜单时候回调的函数。

很多其它内容请关注最新Cocos图书《Cocos2d-x实战 C++卷》?

本书交流讨论站点:http://www.cocoagame.net

很多其它精彩视频课程请关注智捷课堂Cocos课程:http://v.51work6.com

欢迎增加Cocos2d-x技术讨论群:257760386

?

《Cocos2d-x实战 C++卷》现已上线,各大商店均已开售:?

京东:http://item.jd.com/11584534.html

亚马逊:http://www.amazon.cn/Cocos2d-x%E5%AE%9E%E6%88%98-C-%E5%8D%B7-%E5%85%B3%E4%B8%9C%E5%8D%87/dp/B00PTYWTLU

当当:http://product.dangdang.com/23606265.html

互动出版网:http://product.china-pub.com/3770734?

《Cocos2d-x实战 C++卷》源代码及样章下载地址:

源代码下载地址:http://51work6.com/forum.php?

mod=viewthread&tid=1155&extra=page%3D1

样章下载地址:http://51work6.com/forum.php?

mod=viewthread&tid=1157&extra=page%3D1 ?

欢迎关注智捷iOS课堂微信公共平台

版权声明:本文博主原创文章,博客,未经同意不得转载。

时间: 2024-07-31 13:48:33

Cocos2d-x数据持久-变更数据的相关文章

SQL Server 之 - 变更数据跟踪 1

某些应用程序(比如数据仓库系统)十分依赖于源系统的变更数据识别功能,它们期望源系统能够提供一种高效低识别变更数据的能力.在SQLServer 2008之前并没有原生态的解决方案,开发人员不得不通过使用触发器.时间戳以及额外的表来实现该功能,在SQL Server2008之后,数据库提供了两种原生态的特性:Change Tracking(变更追踪)及Change Data Capture(变更数据捕获). 功能对比 简单来讲,所谓变更可以简化为两个问题:①变更有没有发生以及变更的类型:②数据从什么

UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?

选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软推荐使用Sqlite吧! 2,简单!就只有一个类库没有多余的参照什么的.不像其他数据库还得做复杂配置什么的麻烦! 3,不需要数据库服务,数据服务和客户都在同一个进程里面.如下图: 4,作为存储系统它只支持一个用户一个数据实体. 5,跨平台跨结构,这个好! Sqlite主要使用内容 如果想充分使用好S

c++ 数据持久层研究(一)

C++ORM框架自动生成代码数据库 用过Java的都知道SSH框架,特别对于数据库开发,Java领域有无数的ORM框架,供数据持久层调用,如Hibernate,iBatis(现在改名叫MyBatis),TopLink,JDO,JPA……非常方便实用. 用过C#的同学们也都知道通过CodeSmith软件,生成微软的PetShop分层模式,达到数据持久层的代码,也非常方便. 那么我们用C++的怎么办,我们也是面向对象编程,在工作中也有数据库需要管理.我们需要完全手工去写那些重复性的代码吗? 特别我现

数据持久层

1.数据持久化 数据持久化就是将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称. 数据模型可以是任何数据结构或对象模型, 存储模型可以是关系模型.XML.二进制流等. cmp和Hibernate只是对象模型到关系模型之间转换的不同实现. 数据持久化的好处: 1.程序代码重用性强,即使更换数据库,只需要更改配置文件,不必重写程序代码. 2.业务逻辑代码可读性强,在代码中不会有大量的SQL语言,提高程序的可读性. 3.持久化技术可以自动优化,以减少对数据库的访问量,提高程

Java数据持久层框架 MyBatis

MyBatis 详细介绍 MyBatis 的前身就是 iBatis .是一个数据持久层(ORM)框架. iBATIS一词来源于"internet"和"abatis"的组合,是一个基于Java的持久层框架.iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO),同时还提供一个利用这个框架开发的 JPetStore实例. 源码来源:minglisoft.cn/technology

SqlServer 变更数据捕获(CDC)

变更数据捕获(Change Data Capture ,简称 CDC)记录 SQL Server 表的插入.更新和删除活动.使用变更数据捕获可以更有效跟踪表对象DML历史操作,对 ETL 等数据转移也非常有用. 变更数据捕获适用版本: SQL Server 2008 以上的 Enterprise Edition.Developer Edition 和 Evaluation Edition 变更数据捕获原理: 变更数据捕获的更改数据源为 SQL Server 事务日志.当对表启用变更数据捕获时,系

数据持久层(二)

在对象-关系数据库之间提供一个成功的企业 级映射解决方案,尽最大可能弥补这两种范例之间的差异. 持久就是对数据的保持,即对程序状态的保持.通常通过数据库实现持久层是把数据库实现这块当作一个独立逻辑拿出来.说白了,就是数据库程序是在内存中的,为了使程序运行结束后状态得以保存,就要保存到数据库使用ORM(对象关系数据库映射)技术可以避免代码直接操作数据库,增加可移植性,可扩展性,可维护性. J2EE 的三层结构是指表示层( Presentation ),业务逻辑层( Business Logic )

SQL Server 变更数据捕获(CDC)

原文:SQL Server 变更数据捕获(CDC) 标签:SQL SERVER/MSSQL SERVER/数据库/DBA/字段/对象更改 概述 变更数据捕获用于捕获应用到 SQL Server 表中的插入.更新和删除活动,并以易于使用的关系格式提供这些变更的详细信息.变更数据捕获所使用的更改表中包含镜像所跟踪源表列结构的列,同时还包含了解所发生的变更所需的元数据. 对表开启了变更捕获之后,对该表的所有DML和DDL操作都会被记录,有助于跟踪表的变化. 测试环境: SQL SERVER 2008

SQL Server 2008新增的变更数据捕获和更改跟踪

本文主要介绍SQL Server中记录数据变更的四个方法:触发器.Output子句.SQL Server 2008中新增的变更数据捕获(Change Data Capture 即CDC)功能.同步更改跟踪.其中后两个为SQL Server 2008所新增. 一.触发器 在SQL Server的早期版本中,如果要记录某个表或视图的Insert/Update/Delete操作,我们可以借助触发器(Trigger)(http://msdn.microsoft.com/zh-cn/library/ms1