作者:手机用户2602916737 | 来源:互联网 | 2023-05-18 16:14
在c#中声明是[DllImport(sqlite3.dll,EntryPointsqlite3_prepare_v2,CallingConventionCallingConv
在c#中声明是
[DllImport("sqlite3.dll", EntryPoint = "sqlite3_prepare_v2", CallingConvention = CallingConvention.Cdecl)]
public static extern int sqlite3_prepare_v2(IntPtr db, string zSql, int nByte, out IntPtr ppStmpt, IntPtr pzTail);
当没有汉字时
query = "REPLACE into Train(cc,Sf,Fs,Zd,Ds) values('1010','1234','12:34','1010','02:41')";
是没有问题的,但是当使用汉字之后
query = "REPLACE into Train(cc,Sf,Fs,Zd,Ds) values('1010','济南','12:34','1010','02:41')";
调用
sqlite.sqllite.SQLite.sqlite3_prepare_v2(db, query, query.Length, out stmHandle, IntPtr.Zero)
就会出错!我想把汉字插入该怎么处理?谢谢了
12 个解决方案
sqlite3_prepare_v2
是否指定字符集
用 sqlite3_bind_text16
http://blog.csdn.net/a2619308/article/details/6830786
使用sqlite3_bind_text16可以插入了,但是在插入之后是乱码。。。
if(SQLITE_OK != sqlite3_bind_text16(lpdExcute,1,L"海马汽车",-1,SQLITE_STATIC))break;
if(SQLITE_OK != sqlite3_bind_text(lpdExcute,2,"000572",-1,SQLITE_STATIC))break;
--------------------
你可以搜索一下 L"海马汽车" 中的 L 是什么用途
这是中文和英文在存储时的区别