分享
 
 
 

sql server unicode 支持

王朝学院·作者佚名  2009-10-31
窄屏简体版  字體: |||超大  

所有的文档和网上的文章都说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/

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有