快速业务通道

sql server unicode 支持

作者 佚名技术 来源 数据库编程 浏览 发布时间 2012-03-22
所有的文档和网上的文章都说N可以解决问题。但如果使用wstring bind后select...,则会发现得到的 wstring 格式的column很大可能结果是乱码。

其实可以这样解释这个问题:键盘是没法输入uniocde编码的,除非用微软拼音的内码输入。因此数据库的客户端软件输入表的内容并非unicode,即使在表设计的时候用了N。因此select出来的结果并不能用wsting来解析。

那么我们怎么在初始化数据库的时候使用unicode字符串呢?

SQLRETURN SQLExecDirect(
     SQLHSTMT     StatementHandle,

     SQLCHAR *     StatementText,

     SQLINTEGER     TextLength);

sql 在执行的时候,调用SQLExecDirect,其sql语句是SQLCHAR 类型,其实就是unsigned char 的一段空间,并不一定要求这是一个以''\0''结尾的ascii 字符串。如果StatementText是一个ascii 字符串,TextLength可以设置为SQL_NTS。

StatementText是可以嵌入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:

http://www.functionx.com/sqlserver/

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号