zoukankan      html  css  js  c++  java
  • SQL Server ->> SET ANSI_PADDING对于字符串插入的影响

    前面写了《SQL Server ->> 字符串对比》讲了SQL Server在做字符串对比和排序时的对尾随空格的处理方法。

    再说说有一个和字符串尾随空格相关联的东西就是SET ANSI_PADDING选项。

    这个选项只在数据表的字符串字段被更新或者新的数据行插入到表中的时候作用。它控制着SQL Server在遇到字符串尾随空格时是否截断空格,以及是否填充空格以达到预定义的字符字段长度。

    对于已经存储到表里面的字符串数据字段,是不会受影响的(前提是没有在本次被更新)。而且它也只是影响某些字符串类型,像charvarcharbinary, 和varbinary。其他的字符串类型像ncharnvarcharntexttextimagevarbinary(max)varchar(max), and nvarchar(max)并不受影响,原因是它们本身是永远开启SET ANSI_PADDING为ON的。

    微软是建议永远开启这个选项。

    设置

    char(n) NOT NULL 或 binary(n) NOT NULL

    char(n) NULL 或 binary(n) NULL

    varchar(n) 或 varbinary(n)

    ON

    填充原始值(char 列具有尾随空格的值,binary 列具有尾随零的值),以达到列的长度。

    如果 SET ANSI_PADDING 为 ON,则遵从与 char(n) 或 binary(n) NOT NULL 相同的规则。

    不剪裁插入 varchar 列中的字符值的尾随空格。 不剪裁插入 varbinary 列中的二进制值的尾随零。 不将值填充到列的长度。

    OFF

    填充原始值(char 列具有尾随空格的值,binary 列具有尾随零的值),以达到列的长度。

    如果 SET ANSI_PADDING 为 OFF,则遵从与 varchar 或 varbinary 相同的规则。

    剪裁插入 varchar 列中的字符值的尾随空格。 剪裁插入 varbinary 列中的二进制值的尾随零。

  • 相关阅读:
    2022年第一天
    RestTemplate、 Ribbon、 OpenFeign 关系以及OpenFeign使用连接池
    linux下面编写简单的c++程序
    Rocket简介以及单机版安装
    事务源码(二)
    javaagent技术&Attach技术
    gateway网关原理
    Maven自定义插件以及使用
    AotucCrawler 快速爬取图片
    Monkey工具之fastbotiOS实践
  • 原文地址:https://www.cnblogs.com/jenrrychen/p/4974941.html
Copyright © 2011-2022 走看看