LoginSignup
16
16

More than 5 years have passed since last update.

cocos2d-xでsqlite3を使う方法

Last updated at Posted at 2014-12-09

初投稿です。cocos2d-xでsqlite3を使えないか調べていたら
ブログで発見したので自分で試したらうまく動いてくれたので忘却防止の為、投稿します。

準備

sqlite3.hヘッダーファイルをインクルードします。

HelloWorldScene.cpp
#include "sqlite3.h" 

テーブルの作成

HelloWorldScene.cpp

    // SQLITE3
    sqlite3 *pDB = NULL;
    char* errMsg = NULL;
    std::string sqlstr;
    int result;
    std::string dbPath = CCFileUtils::sharedFileUtils()->getWriteablePath();
    dbPath.append("Test.db");
    result = sqlite3_open(dbPath.c_str(),&pDB);
    if (result != SQLITE_OK){
        CCLOG("OPENING WRONG, %d, MSG:%s",result,errMsg);
    }else{
        CCLOG("OK! %d, %s",result,errMsg);
    }

    // 読み書きファイルパスの表示
    CCLog("%s",dbPath.c_str());

    result=sqlite3_exec( pDB, "create table MyTable_1( ID integer primary key autoincrement, name nvarchar(32) ) " , NULL, NULL, &errMsg );
    if( result != SQLITE_OK )
        CCLog( "失敗 :%d ,原因:%s\n" , result, errMsg );

    //insert
    sqlstr=" insert into MyTable_1( name ) values ( 'いちご' ) ";
    result = sqlite3_exec( pDB, sqlstr.c_str() , NULL, NULL, &errMsg );
    if(result != SQLITE_OK )
        CCLog( "失敗 :%d ,原因:%s\n" , result, errMsg );

    //insert
    sqlstr=" insert into MyTable_1( name ) values ( 'ぶどう' ) ";
    result = sqlite3_exec( pDB, sqlstr.c_str() , NULL, NULL, &errMsg );
    if(result != SQLITE_OK )
        CCLog( "失敗 :%d ,原因:%s\n" , result, errMsg );

    //insert
    sqlstr=" insert into MyTable_1( name ) values ( 'ばなな' ) ";
    result = sqlite3_exec( pDB, sqlstr.c_str() , NULL, NULL, &errMsg );
    if(result != SQLITE_OK )
        CCLog( "失敗 :%d ,原因:%s\n" , result, errMsg );

    sqlite3_close(pDB);
16
16
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
16