zoukankan      html  css  js  c++  java
  • sql collate 子句 排序规则

    SQL SERVER的排序规则平时使用不是很多,也许不少初学者还比较陌生,但有
    一个错误大家应是经常碰到: SQL SERVER数据库,在跨库多表连接查询时,若两数据
    库默认字符集不同,系统就会返回这样的错误:
          
               “无法解决 equal to 操作的排序规则冲突。”

    COLLATE 是一个子句,可应用于数据库定义或列定义以定义排序规则,或应用于字符串表达式以应用排序规则转换。

    语法

    COLLATE { <collation_name> | database_default }
    <collation_name> :: = 
         { Windows_collation_name } | { SQL_collation_name }

    collation_name  应用于表达式、列定义或数据库定义的排序规则的名称。

    database_default    使 COLLATE 子句继承当前数据库的排序规则。

    一.错误分析:
      这个错误是因为排序规则不一致造成的,我们做个测试,比如:

    create table #t1(
    name varchar(20) collate Albanian_CI_AI_WS,  
    value int)
    
    create table #t2(
    name varchar(20) collate Chinese_PRC_CI_AI_WS,    
    value int )
    
    表建好后,执行连接查询:
    
    select * from #t1 A inner join #t2 B on A.name=B.name 

    这样,错误就出现了:

               服务器: 消息 446,级别 16,状态 9,行 1
               无法解决 equal to 操作的排序规则冲突。

    要排除这个错误,最简单方法是,表连接时指定它的排序规则,这样错误就
    不再出现了。语句这样写:

    select * from #t1 A inner join #t2 B on A.name collate database_default=B.name collate database_default 
    select * from #t1 A inner join #t2 B on A.name =B.name collate database_default 

    语法规则 字段名后跟    collate database_default  建议用  collate database_default 这样的话 继承自 当前数据库排序规则 避免后续有不必要的麻烦

  • 相关阅读:
    使用批处理文件轻松更改本地IP地址
    Aveiconifier是一个非常实用方便的制作ico格式文件的小工具~
    C#中选择文件的例子
    WindowsXP命令行修改服务启动选项
    Oracle中数据导入导出技巧
    hibernateTemplateOrder Results
    如何向 Microsoft 管理控制台添加证书管理器
    maven usages
    让Eclipse拥有像Visual Studio一样的强大的提示功能
    jsp页面跳转方法及区别
  • 原文地址:https://www.cnblogs.com/su-king/p/10043911.html
Copyright © 2011-2022 走看看