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 列中的二进制值的尾随零。

  • 相关阅读:
    Git 基础教程 之 解决合并冲突
    Git 基础教程 之 远程库更新到本地
    Git 基础教程 之 分支管理及策略
    Git 基础教程 之 从远程库克隆
    Git 基础教程 之 添加远程仓库
    Git 基础教程 之 远程仓库
    c++11新特性1--------------auto
    线程及线程间同步
    进程间通信---信号
    进程间通信---mmap详解(与system V ipc通信对照)
  • 原文地址:https://www.cnblogs.com/jenrrychen/p/4974941.html
Copyright © 2011-2022 走看看