• (SqlServe)关于字符串长度被截断的问题


    1. 问题描述

    在同步数据时常常会发现一个错误:将截断字符串或二进制数据

    2. 问题原因

    这个问题出现的原因是:要插入的数值字段的长度超出了数据库中字段的长度。比如:插入的字符串字节长度是40,数据库中字段长度设置为了varchar(36)就会报此错误。

    3.问题扩展

    a. 如何计算字符串长度和字节长度,既:datalength和len区别。
    len:返回字符串的长度
    datalength:返回字符串的字节长度

    select len(convert(varchar(50),N'狮lion')) --5 N''表示Unicode格式字符串
    select datalength(convert(varchar(50),N'狮lion')) --6
    select len(N'狮lion') --5
    select datalength(N'狮lion')	--10
    

    接下来我们分析一下为何会这样.
    len返回字符串的字符长度,既:一个汉字'狮'+4个字母'lion'=5个字符。每个汉字和字母都占一个字符长度。
    datalength返回字符串的字节长度。对于字节长度,需要理解:一般编码模式下,汉字和英文字母所占字节是不一样的。一般来说,汉字占2个字节,英文字符占一个字节。而对于Unicode编码,汉字和英文字母都占2个字节。
    讲解一下varchar和nvarchar的区别,varchar是普通编码的字符串,nvarchar是Unicode编码的字符串,对应例子,就是对汉字'狮'来说,varchar格式的字符串长度为1,nvarchar格式的字符串长度为2。

    len(convert(varchar(50),N'狮lion')) --返回字符长度,'狮lion',一共5个字符,varchar格式字符
    len(N'狮lion') --返回字符长度,'狮lion',一共5个字符,nvarchar格式字符
    datalength(convert(varchar(50),N'狮lion')) --返回字节长度,varchar格式字符'狮lion','狮'占2个字节,
                                                  --'lion'中每个字母占用一个字节,共占用4个字节
    datalength(N'狮lion') --返回字节长度,Unicode格式字符,汉字'狮'占2个字节,
                                   --'lion'中每个字母占用2个字节,共占用8个字节
    

    文章引用:https://blog.csdn.net/oncealong/article/details/37573927

    b. 如何查看数据库的编码格式。

    --查看sqlserver数据库的编码格式
    SELECT COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage');
    查询结果: 
    936 简体中文GBK 
    950 繁体中文BIG5 
    437 美国/加拿大英语 
    932 日文 
    949 韩文 
    866 俄文 
    65001 unicode UFT-8
    

    c. varchar和char和nvarchar三者的区别

    1. char是定长(固定长度),效率高于varchar;也就是当你输入的字符小于你指定的数目时,例如:char(8),你输入的字符小于8时,它会再后面补空值。当你输入的字符大于指定的数时,它会截取超出的字符。
    2. varchar[n]是变长且非unicode字符数据类型,n的取值在1到8000之间,该类型英文字符占一个字节,中文字符占两个字节。优点:更加合理利用空间,不会造成过多的浪费。
    3. nvarchar[n]是变长且unicode字符数据类型,n的取值在1到4000之间,该类型字符无论中英文都占取两个字节
      其中varchar和nvarchar两字段分别有字段值:你好hello
      那么varchar字段占2×2+5=9个字节的存储空间,而nvarchar字段占7×2=14个字节的存储空间。
      如字段值只是英文可选择varchar,而字段值存在较多的双字节(中文、韩文等)字符时用nvarchar

    文章引用:https://www.cnblogs.com/flqcchblog/p/4560781.html

  • 相关阅读:
    2020-2021-1 20201216 《信息安全专业导论》第十周学习总结
    2020-2021-1 20201216 《信息安全专业导论》第9周学习总结
    熟悉编程语言
    2020-2021-1 20201216 《信息安全专业导论》第八周学习总结
    如何学好编程
    2020-2021第一学期20202428《计算机科学概论》第二周自习总结
    “七剑下天山”学习小组第一周学习中遇到的问题及解决
    2020-2021第一学期20202407《计算机科学概论》第一次学习总结
    开启我的测试之路
    大数据测试
  • 原文地址:https://www.cnblogs.com/littlewu/p/12153368.html
Copyright © 2020-2023  润新知