C++字符集的相互传换 and sqlite3_open 返回14

转载 2013年12月03日 10:08:58

sqlite3_open 返回14,文件路径包含中文。

解决方法:插入前,把SQL语句转UTF8格式。



C++字符集的相互传换   


#include <windows.h>

#include <vector>

#include <string>

using namespace std;

 

//utf8 转 Unicode

std::wstring Utf82Unicode(const std::string& utf8string)
{
 int widesize = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, NULL, 0);
 if (widesize == ERROR_NO_UNICODE_TRANSLATION)
 {
  throw std::exception("Invalid UTF-8 sequence.");
 }
 if (widesize == 0)
 {
  throw std::exception("Error in conversion.");
 }
 
 std::vector<wchar_t> resultstring(widesize);
 
 int convresult = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, &resultstring[0], widesize);
 
 if (convresult != widesize)
 {
  throw std::exception("La falla!");
 }
 
 return std::wstring(&resultstring[0]);
}


//unicode 转为 ascii

string WideByte2Acsi(wstring& wstrcode)
{
 int asciisize = ::WideCharToMultiByte(CP_OEMCP, 0, wstrcode.c_str(), -1, NULL, 0, NULL, NULL);
 if (asciisize == ERROR_NO_UNICODE_TRANSLATION)
 {
  throw std::exception("Invalid UTF-8 sequence.");
 }
 if (asciisize == 0)
 {
  throw std::exception("Error in conversion.");
 }
    std::vector<char> resultstring(asciisize);
 int convresult =::WideCharToMultiByte(CP_OEMCP, 0, wstrcode.c_str(), -1, &resultstring[0], asciisize, NULL, NULL);
 
 if (convresult != asciisize)
 {
  throw std::exception("La falla!");
 }
 
    return std::string(&resultstring[0]);
}

 

//utf-8 转 ascii

string UTF_82ASCII(string& strUtf8Code)
{
 string strRet("");


 //先把 utf8 转为 unicode 
 wstring wstr = Utf82Unicode(strUtf8Code);

 //最后把 unicode 转为 ascii
 strRet = WideByte2Acsi(wstr);


 return strRet;
}

///////////////////////////////////////////////////////////////////////

//ascii 转 Unicode

wstring Acsi2WideByte(string& strascii)
{
 int widesize = MultiByteToWideChar (CP_ACP, 0, (char*)strascii.c_str(), -1, NULL, 0);
 if (widesize == ERROR_NO_UNICODE_TRANSLATION)
 {
  throw std::exception("Invalid UTF-8 sequence.");
 }
 if (widesize == 0)
 {
  throw std::exception("Error in conversion.");
 }
    std::vector<wchar_t> resultstring(widesize);
 int convresult = MultiByteToWideChar (CP_ACP, 0, (char*)strascii.c_str(), -1, &resultstring[0], widesize);

 if (convresult != widesize)
 {
  throw std::exception("La falla!");
 }
 
    return std::wstring(&resultstring[0]);
}

//Unicode 转 Utf8

std::string Unicode2Utf8(const std::wstring& widestring)
{
 int utf8size = ::WideCharToMultiByte(CP_UTF8, 0, widestring.c_str(), -1, NULL, 0, NULL, NULL);
 if (utf8size == 0)
 {
  throw std::exception("Error in conversion.");
 }
 
 std::vector<char> resultstring(utf8size);
 
 int convresult = ::WideCharToMultiByte(CP_UTF8, 0, widestring.c_str(), -1, &resultstring[0], utf8size, NULL, NULL);
 
 if (convresult != utf8size)
 {
  throw std::exception("La falla!");
 }
 
 return std::string(&resultstring[0]);
}

//ascii 转 Utf8

string ASCII2UTF_8(string& strAsciiCode)
{
 string strRet("");


 //先把 ascii 转为 unicode 
 wstring wstr = Acsi2WideByte(strAsciiCode);

 //最后把 unicode 转为 utf8

 strRet = Unicode2Utf8(wstr);


 return strRet;
}



Link:

http://blog.163.com/gaoguangtao_love/blog/static/38483715200874111519785/

http://blog.163.com/gaoguangtao_love/blog/static/3848371520114274236119/

相关文章推荐

在操作数据库时候出现 sqlite3_open_v2("/data/data/xxx/databases/xxx.db", &handle, 6)failed

最近在做apk升级的时候数据库方出现了如标题一样的问题,一直没找到问题所在,请各位知情人士帮个忙。   大概是这样我做了一个应用,需要版本升级,升级的时候应用所用的数据库表字段有所修改,同事增加了...

sqlite3_open()

Opening A New Database Connection int sqlite3_open( const char *filename, /* Database filenam...
  • Koupoo
  • Koupoo
  • 2012年08月05日 09:14
  • 802

Android学习笔记(14)---sqlite3的使用

1、首先进入: 2、使用cd命令进入所找数据库所在的位置并使用sqlite3命令 3、使用.schema命令 4、选择某个表 上面可以看到表中的数据...
  • Moruna
  • Moruna
  • 2012年08月12日 20:00
  • 839

Python标准库14 数据库 (sqlite3)

Python标准库14 数据库 (sqlite3)   Python自带一个轻量级的关系型数据库SQLite。这一数据库使用SQL语言。SQLite作为后端数据库,可以搭配Python建网站,或者...

Python sqlite3 and concurrency

  • 2012年04月27日 11:56
  • 374KB
  • 下载

iOS CoreData and Sqlite3 Demo

  • 2014年12月02日 08:55
  • 3.29MB
  • 下载

sqlite学习笔记之sqlite3_open函数的使用

作者:朱金灿来源:http://blog.csdn.net/clever101        打开sqlite数据库需要用到sqlite3_open函数,但是sqlite3_open函数的第一个参数是...

IOS sqlite简单使用 以及为什么sqlite3_open无法创建数据库的原因

一、IOS数据存储方式 1.IOS中数据的存储方式有: 1)plist(NSArray、NSDictionary) 2)Preference(偏好设置,NSUserDefaulters) 3)...

iOS and sqlite3

SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。 基本操作: (1)打开或者创建数据库 sqlite3 *database...
  • alanzn
  • alanzn
  • 2012年08月27日 15:10
  • 308

Linux_TCP_SQLite3: Implementation of a small embedded system including receiving and saving data.

1. Background The system is designed to implement the function of receiving data by TCP/IP from the...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C++字符集的相互传换 and sqlite3_open 返回14
举报原因:
原因补充:

(最多只允许输入30个字)