当数据变化,参与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课堂微信公共平台

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

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

  1. SQL Server 变更数据捕获(CDC)监控表数据

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现过程(Realization) 补充说明(Addon) 参考文献(References) ...

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

    选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...

  3. SQL Server 变更数据捕获(CDC)

    标签:SQL SERVER/MSSQL SERVER/数据库/DBA/字段/对象更改 概述 变更数据捕获用于捕获应用到 SQL Server 表中的插入.更新和删除活动,并以易于使用的关系格式提供这些 ...

  4. Restful.Data v1.0 - 轻量级数据持久层组件, 正式开源发布了

    经过几个星期的优化调整,今天 Restful.Data 正式开源发布. 源码地址:https://github.com/linli8/Restful 今天不写那么多废话了,还是重新介绍一下 Restf ...

  5. .NET平台下,关于数据持久层框架

    在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...

  6. SQL Server 2008中新增的 1.变更数据捕获(CDC) 和 2.更改跟踪

    概述 1.变更数据捕获(CDC)        每一次的数据操作都会记录下来 2.更改跟踪       只会记录最新一条记录   以上两种的区别:         http://blog.csdn.n ...

  7. SQL Server 2008中新增的变更数据捕获(CDC)和更改跟踪

    来源:http://www.cnblogs.com/downmoon/archive/2012/04/10/2439462.html  本文主要介绍SQL Server中记录数据变更的四个方法:触发器 ...

  8. .NET开源项目介绍及资源推荐:数据持久层

    在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...

  9. .NET平台数据持久层框架

    在.NET平台下的几个数据持久层框架: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS.NET 5.DAAB 6.DLinq

随机推荐

  1. Java就业前景怎么样?学了后好找工作吗?

    不知道大家对Java就业前景了解多少.随着信息化的发展.IT培训受倒了越来越多人的追捧.在开发领域,JAVA培训成为了很多人的首选!JAVA应用广泛.JAVA培训就业前景良好. 眼下.尽管JAVA人才 ...

  2. HDFS 上传文件的不平衡,Balancer问题是过慢

    至HDFS上传文件.假定从datanode开始上传文件,上传的数据将导致目前的当务之急是全datanode圆盘.这是一个分布式程序的执行是非常不利. 解决方案: 1.从其他非datanode节点上传 ...

  3. iOS pragma mark要使用

    郝萌主倾心贡献,尊重作者的劳动成果.请勿转载. 假设文章对您有所帮助.欢迎给作者捐赠.支持郝萌主,捐赠数额任意.重在心意^_^ 我要捐赠: 点击捐赠 Cocos2d-X源代码下载:点我传送 简单的来说 ...

  4. OpenCV——Delaunay三角 [转载]

    从这个博客转载 http://blog.csdn.net/raby_gyl/article/details/17409717 请其它同学转载时注明原始文章的出处! Delaunay三角剖分是1934年 ...

  5. 《Tips for Optimizing C/C++ Code》译文

    前不久在微博上看到一篇非常好的短文讲怎样对C/C++进行性能优化,尽管其面向的领域是图形学中的光线跟踪,可是还是具有普遍的意义,将其翻译成中文,希望对大家写高质量代码有帮助. 1.     牢记阿姆达 ...

  6. crm2011i创建nt类型字段

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Xrm.Sdk.Messages;     using Microsoft ...

  7. 大约Java有点感悟---开发商根本上感悟学习

    这些年来一直从事大C.C++,有些局部底.一直想知道更多关于顶级什么. 所以,在工作之余.阅读更多Java哪些方面,还使用了一些建筑结构的一些简单的程序,在这里我想简单谈谈自己的一点感悟. 1.Jav ...

  8. Spring : 征服数据库 (两)

    本节介绍Spring和ORM集成框架.尽管Hibernate在开源ORM 社区很受欢迎.但是,本文将MyBatis案例解说.也MyBatis和Hibernate好坏是没有意义的,主要看实际需求,有兴趣 ...

  9. Bag标签成一条线的代码来实现中国字

    说明: <Bag id=书包名 act=2words[name=key] [gap=字符] [quotes=引號]>中英文混合内容</Bag> 例0: 默认分词(无gap和qu ...

  10. mysql经常使用命令总结

    MySQL经常使用指令(备查) 最经常使用的显示命令: 1.显示数据库列表.  show databases;  2.显示库中的数据表:  use mysql; show tables;  3.显示数 ...