以下的文章主要向大家讲述的是SQL Server unicode 支持,假如你对SQL Server unicode的实际应用有兴趣了解的话,你就可以通过以下的文章对其有更好的了解,以下就是具体方案的描述,希望在你今后的学习中会有所帮助。
所有的文档和网上的文章都说N可以解决问题。但如果使用wstring bind后select...,则会发现得到的 wstring 格式的column很大可能结果是乱码。
其实可以这样解释这个问题:键盘是没法输入uniocde编码的,除非用微软拼音的内码输入。因此数据库的客户端软件输入表的内容并非SQL Server unicode,即使在表设计的时候用了N。因此select出来的结果并不能用wsting来解析。
那么我们怎么在初始化数据库的时候使用SQL Server unicode字符串呢?
- SQLRETURN SQLExecDirect(
- SQLHSTMT StatementHandle,
- SQLCHAR * StatementText,
- SQLINTEGER TextLength);
sql 在执行的时候,调用SQLExecDirect,其sql语句是SQLCHAR 类型,其实就是unsigned char 的一段空间,并不一定要求这是一个以'\0'结尾的ascii 字符串。如果StatementText是一个ascii 字符串,TextLength可以设置为SQL_NTS。
StatementText是可以嵌入SQL Server unicode字符的,比如使用INSERT INTO T (c1,c2) VALUES(N'unicode string',data),这时候TextLength要填入整个串的长度而不是SQL_NTS。
拼写出这样一个串既不能用窄字符串的函数集合,也不能用宽字符串的函数集合。这里使用memcpy类的函数来构造这样的串,然后调用SQLExecDirect,取得了成功。比如,
- USE [test]
- GO
- SET ANSI_NULLS ON
- GO
- SET QUOTED_IDENTIFIER ON
- GO
- CREATE TABLE [dbo].[电话薄](
- [姓名] [ntext] NULL,
- [电话] [nchar](32) NULL
- ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
- /*
- * insert a unicode string into the table
- *
- */
- struct buf_s{
- void * buf;
- int len;
- };
- /*
- *just be same as memcpy ,except for the return.
- */
- int memapend(void * dst, void * src ,int len)
- {
- memcpy(dst,src,len);
- return len;
- }
- void insert()
- {
- unsigned char sql_buf[256]={0};
- int len_sql=0;
- char str1[]="insert into 电话薄 (姓名,电话) values(N'";
- int len1=strlen(str1);
- wchar_t str2[]=L"张三";
- int len2=wcslen(str2)*sizeof(wchar_t);
- char str3[]="',N'";
- int len3=strlen(str3);
- wchar_t str4[]=L"010123456";
- int len4=wcslen(str4)*sizeof(wchar_t);
- char str5[]="')";
- int len5=strlen(str5);
- buf_s buf_s_a []={str1,len1,
- str2,len2,
- str3,len3,
- str4,len4,
- str5,len5};
- for (int i=0;i<sizeof(buf_s_a)/sizeof(buf_s);i++)
- {
- len_sql+=memapend(sql_buf+len_sql, buf_s_a[i].buf,buf_s_a[i].len);
- }
- SQLExecDirect(h,sql_buf,len_sql);
- }
- btw:find a good site for ms_sqlserver:
以上的相关内容就是对SQL Server unicode 支持的介绍,望你能有所收获。
【编辑推荐】