SQLServerunicode支持的具体体现

以下的文章主要向大家讲述的是SQL Server unicode 支持,假如你对SQL Server unicode的实际应用有兴趣了解的话,你就可以通过以下的文章对其有更好的了解,以下就是具体方案的描述,希望在你今后的学习中会有所帮助。

超过十多年行业经验,技术领先,服务至上的经营模式,全靠网络和口碑获得客户,为自己降低成本,也就是为客户降低成本。到目前业务范围包括了:成都网站设计、成都网站建设,成都网站推广,成都网站优化,整体网络托管,小程序制作,微信开发,成都app软件开发,同时也可以让客户的网站和网络营销和我们一样获得订单和生意!

所有的文档和网上的文章都说N可以解决问题。但如果使用wstring bind后select...,则会发现得到的 wstring 格式的column很大可能结果是乱码。

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

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

 
 
 
  1. SQLRETURN SQLExecDirect(  
  2. SQLHSTMT StatementHandle,  
  3. SQLCHAR * StatementText,  
  4. 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,取得了成功。比如,

 
 
 
  1. USE [test]  
  2. GO  
  3. SET ANSI_NULLS ON  
  4. GO  
  5. SET QUOTED_IDENTIFIER ON  
  6. GO  
  7. CREATE TABLE [dbo].[电话薄](  
  8. [姓名] [ntext] NULL,  
  9. [电话] [nchar](32) NULL  
  10. ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]  
  11. /*  
  12. * insert a unicode string into the table  
  13. *  
  14. */  
  15. struct buf_s{  
  16. void * buf;  
  17. int len;  
  18. };  
  19. /*  
  20. *just be same as memcpy ,except for the return.  
  21. */  
  22. int memapend(void * dst, void * src ,int len)  
  23. {  
  24. memcpy(dst,src,len);  
  25. return len;  
  26. }  
  27. void insert()  
  28. {  
  29. unsigned char sql_buf[256]={0};  
  30. int len_sql=0;  
  31. char str1[]="insert into 电话薄 (姓名,电话) values(N'";  
  32. int len1=strlen(str1);  
  33. wchar_t str2[]=L"张三";  
  34. int len2=wcslen(str2)*sizeof(wchar_t);  
  35. char str3[]="',N'";  
  36. int len3=strlen(str3);  
  37. wchar_t str4[]=L"010123456";  
  38. int len4=wcslen(str4)*sizeof(wchar_t);  
  39. char str5[]="')";  
  40. int len5=strlen(str5);  
  41. buf_s buf_s_a []={str1,len1,  
  42. str2,len2,  
  43. str3,len3,  
  44. str4,len4,  
  45. str5,len5};  
  46. for (int i=0;i
  47. {  
  48. len_sql+=memapend(sql_buf+len_sql, buf_s_a[i].buf,buf_s_a[i].len);  
  49. }  
  50. SQLExecDirect(h,sql_buf,len_sql);  
  51. }  
  52. btw:find a good site for ms_sqlserver:  

以上的相关内容就是对SQL Server unicode 支持的介绍,望你能有所收获。

【编辑推荐】

  1. SQL Server 易混淆的一些数据类型有哪些?
  2. SQL Server 日期操作全接触,嘻嘻
  3. 对SQL Server 2005 BI的描述
  4. 批量修改SQL Server 2005表构架很简单!
  5. MS SQL Server 2000系统数据类型有哪些?
     

分享名称:SQLServerunicode支持的具体体现
本文地址:http://www.mswzjz.cn/qtweb/news40/26990.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能