All articles(网络文学目录) All Pictures(图片目录) All Softwares(软件目录)

 
sql,server,unicode,支持_mssql学习_编程技术

Writer: delv Article type: Programming skills(编程技巧) Time: 2013/12/30 4:36:42 Browse times: 335 Comment times: 0

sql,server,unicode,支持_mssql学习_编程技术


Head photo

Go homepage
Upload pictures
Write articles

sql server unicode 支持_mssql学习_编程技术-你的首页-uuhomepage.com所有的文档和网上的文章都说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]GOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCREATE 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




There are 0 records,
Comment:
Must be registered users to comment(必须是注册用户才能发表评论)

Disclaimer Privacy Policy About us Site Map
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.