当前位置:首页 > 系统运维 > 正文内容

SQL Server unicode 支持的具体体现

a8116255316年前 (2010-07-12)系统运维7

以下的文章主要向大家讲述的是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 的一段空间,并不一定要求这是一个以''结尾的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 支持的介绍,望你能有所收获。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/21890.html

分享给朋友:

“SQL Server unicode 支持的具体体现” 的相关文章

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

在某些电脑中,机器内部蜂鸣器与系统的声音输出方案是相关联的,这样一来会导致当系统输出声音时,即使电脑没有连接外部音响或耳机,也会通过内置蜂鸣器发出“嘟嘟哔哔”的声音。这个问题主要出现在Windows 7电脑中,假如你的电脑恰好遇到了这样的问题,可参考下面的方法来解决: 1、在桌面“计算机”图标上右...

如何设置Win 7通知栏重新显示电源按钮

如何设置Win 7通知栏重新显示电源按钮

有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...

windows 7查看电脑近期使用情况确定有没有被他人使用

windows 7查看电脑近期使用情况确定有没有被他人使用

我一个朋友最近装装了Windows 7,他总感觉有人用了他的电脑,但是一直不确定,他想知道有没有人动用他的电脑,问我有没有办法 我说设置一下就行了: 启动Windows 7,在搜索栏中输入编辑组,马上就搜索到了编辑组策略,点击即可启动程序编辑组策略。依次展开组策略左侧树形列表的计算机配置/管理模...

windows7系统下让所有文件夹都使用同一种视图的方法

windows7系统下让所有文件夹都使用同一种视图的方法

Windows 7系统可以对每个文件夹进行个性化视图设置,可以根据自己的个人喜好和实际需要更改文件或文件夹图标的大小,或者让文件或文件夹以列表、平铺等方式显示。但是,假如你对N个文件夹视图进行了风格各异的个性设置,现在又想让所有文件夹都使用同一种视图怎么办呢 手工一个一个修改,你OUT了,非累得手抽...

windows 7系统中不能把程序锁定到任务栏的解决方法图文讲解

windows 7系统中不能把程序锁定到任务栏的解决方法图文讲解

最近小编在使用Windows 7的时侯遇到一个问题,就是应用程序和快捷方式不能锁定到任务栏,我当时不知道怎么回事,但是很多现有的方法都不能解决这个问题。现在我把我的解决的方法分享给大家以作参考。 问题分析 经过思考,初步判断出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。...