来源:the collation conflict between "chinese_prc_ci_as" and "sql_latin1_general_cp1_ci_as" in the equal to operation - 游子看世界 - 博客园

https://www.cnblogs.com/shuqian/archive/2012/03/16/2397642.html

昨天升级存储过程后发现报这个错误

cannot resolve the collation conflict between "chinese_prc_ci_as" and "Chinese_Taiwan_Stroke_CI_AS_WS" in the equal to operation

发现时某存储过程中的创建的临时表存在排序规则冲突。

 

 

CCE3.03的服务器采用英文的2003R2 数据库排序规则为拉丁文忽略大小写.

我的存储过程中遇到了"无法解决 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之间的排序规则冲突。"百度一下 ^_^

由于采用了 临时表 导致使用了数据库默认的字符排序规则 导致:

表sohead字段so_num的Collate跟数据库默认的Collate不一样造成的,创建临时表,对字符类型的字段使用数据库默认的Collate,如果这个跟表的字段Collate不同时,SQL Server无法对这两个字段进行比较

解决:把sohead字段so_num的Collate改成跟数据库默认的一致,或者改数据库默认的Collate,或者创建临时表时指定Collate

  

附录:

在执行SQL语句时,可能会遇到:“无法解决 equal to 操作中的 **** 和 *******排序规则冲突”

一.错误分析:
  这个错误是因为排序规则不一致造成的,我们做个测试,比如:
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=B.name collate Chinese_PRC_CI_AI_WS


二.排序规则简介:

    什么叫排序规则呢?MS是这样描述的:"在 Microsoft SQL Server 2000 中,
字符串的物理存储由排序规则控制。排序规则指定表示每个字符的位模式以及存
储和比较字符所使用的规则。"
  在查询分析器内执行下面语句,可以得到SQL SERVER支持的所有排序规则。

    select * from ::fn_helpcollations()

排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。
如:
  Chinese_PRC_CS_AI_WS
前半部份:指UNICODE字符集,Chinese_PRC_指针对大陆简体字UNICODE的排序规则。
排序规则的后半部份即后缀 含义:
  _BIN 二进制排序
  _CI(CS) 是否区分大小写,CI不区分,CS区分
  _AI(AS) 是否区分重音,AI不区分,AS区分   
  _KI(KS) 是否区分假名类型,KI不区分,KS区分 
    _WI(WS) 是否区分宽度 WI不区分,WS区分 

区分大小写:如果想让比较将大写字母和小写字母视为不等,请选择该选项。
区分重音:如果想让比较将重音和非重音字母视为不等,请选择该选项。如果选择该选项,
         比较还将重音不同的字母视为不等。
区分假名:如果想让比较将片假名和平假名日语音节视为不等,请选择该选项。
区分宽度:如果想让比较将半角字符和全角字符视为不等,请选择该选项


三、解决方法

1.将数据库中一个表的字段改成与另一个表中要比较的字段相同的排序规则。

2.在SQL语句的Where子句后面加上类似这样的SQL片段:collate Chinese_PRC_CI_AI_WS

    如:

Select A.* From A,B Where A.a = B.b collate Chinese_PRC_CI_AI_WS

 

posted @ 2024-12-27 09:59 老飞飞 阅读(17) 评论(1) 推荐(0) 编辑
摘要: 现在数据库中一个字段保存的是json字符串,比如:"{"code":0,"msg":"OK"}",可是如果直接返回,会在javascript 的 var data = jQuery.parseJSON(data1); 的时候出错。 正确的处理方式是 url="["+thisDr["jsonText" 阅读全文
posted @ 2024-12-06 11:28 老飞飞 阅读(10) 评论(0) 推荐(0) 编辑
摘要: form程序有时候会使用到目录,比如写log文件等。 这个时候强烈推荐大家使用AppDomain.CurrentDomain.BaseDirectory来获得当前目录, 不建议使用Environment.CurrentDirectory。 理由是:如果将exe拖个快捷方式到桌面,Environmen 阅读全文
posted @ 2024-12-04 17:20 老飞飞 阅读(3) 评论(0) 推荐(0) 编辑
摘要: 需求:一个待办事项列表页面(A页面),点击新开一个处理待办的页面(B页面)。在B页面上点击一个按钮(处理这件事情)后, 要求A页面进行刷新,主要目的是去掉进入B页面的链接,避免进行2次处理等。 找到页面传输数据的方法,首先想到的是cookie。 代码开整,在B页面设定cookie ,main_ref 阅读全文
posted @ 2024-10-09 11:46 老飞飞 阅读(12) 评论(0) 推荐(0) 编辑
摘要: XSSFCellStyle headStyle = workBook.CreateCellStyle() as XSSFCellStyle; headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; XSSFFont fo 阅读全文
posted @ 2024-09-16 21:26 老飞飞 阅读(24) 评论(0) 推荐(0) 编辑
摘要: 转自:SAP如何debug远程调用的函数模块 (SAP: How to debug RFC) - SAP Community 我是大自然的搬运工 很多ABAP的初学者在debug程序的时候经常会遇到一个问题,那就是RFC的function module的debug问题,例如,A系统的程序中通过RFC 阅读全文
posted @ 2024-07-18 08:30 老飞飞 阅读(95) 评论(0) 推荐(0) 编辑
摘要: https://www.cnblogs.com/friend/p/16754184.html\ public async Task<int> Save(long moldProducedProductId, List<MoldStandardResource> list) { int result 阅读全文
posted @ 2024-05-03 16:25 老飞飞 阅读(67) 评论(0) 推荐(0) 编辑
摘要: 需求:如果是新建的单据,就不允许进行勾选;如果打开之前建立的旧单,就可以进行勾选。 假设前面增加的选择项的部分是 { field: 'index1', checkbox: true, fixed: true, }, 我们需要在done事件中进行判断 , done: function (res, cu 阅读全文
posted @ 2024-04-04 16:20 老飞飞 阅读(497) 评论(0) 推荐(0) 编辑
摘要: 转载于:https://baijiahao.baidu.com/s?id=1724200064045898644&wfr=spider&for=pc 为了避免运行时编译cshtml造成的性能问题,ASP.NET Core MVC项目在发布的时候默认会把cshtml文件编译到dll中,但是有的项目希望 阅读全文
posted @ 2024-01-10 08:29 老飞飞 阅读(38) 评论(0) 推荐(0) 编辑
摘要: 2023-12-27 jquery 3.4.1 升级问题 被稽核部门认为jquery使用的3.41存在漏洞,要求升级到3.4.2以上版本 首先升级到jquery3.5.1,结果发现ajax部分都存在问题,比如$.ajax,$.post都会报错,看到3.5.1的备注发现 -ajax等的备注 马上找到j 阅读全文
posted @ 2023-12-27 15:16 老飞飞 阅读(40) 评论(0) 推荐(0) 编辑
点击右上角即可分享
微信分享提示