- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我总是收到消息“无法解决等于操作中“SQL_Latin1_General_CP1_CI_AS”和“Latin1_General_CI_AI”之间的排序规则冲突。”当我运行来自 MSSQL 2005 服务器的脚本时。顺便说一句,我使用的是 MSSQL 2008。
这是脚本
USE [database1]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--exec rsp_SOA '', '', '', '', '', '', '40050000', '40050000', '05/01/2010', '05/31/2010', '000-00','Dont Show Note'
ALTER procedure [dbo].[rsp_SOA]
@cCompName VARCHAR(100) ,
@cAddress1 VARCHAR(200) ,
@cAddress2 VARCHAR(200),
@cReportTitle VARCHAR(200),
@cCriteria1 VARCHAR(200),
@cCriteria VARCHAR(200),
@cFrom VARCHAR(25),
@cTo VARCHAR(25),
@dDateFrom VARCHAR(10),
@dDateTo VARCHAR(10),
@cCompID VARCHAR(10),
@cFilter VARCHAR(30)
as
declare @cSQL VARCHAR(200),
@cSQL1 VARCHAR(200),
@cmd VARCHAR(8000),
@cmd1 VARCHAR(8000),
@cTempTable varchar (50),
@cTempTable1 varchar (50),
@nInterval VARCHAR(3),
@nCurrent INTEGER,
@nInterval1 varchar(3),
@nInterval2 varchar(3),
@nInterval3 varchar(3),
@nInterval4 varchar(3),
@nInterval5 varchar(3),
@dd INTEGER,
@cValue1 VARCHAR(100),
@cValue2 VARCHAR(100),
@cValue3 VARCHAR(100),
@cValue4 VARCHAR(100),
@cValue5 VARCHAR(100)
set @nInterval = 30
set @nInterval1 = cast(@nInterval * 1 as varchar(3))
set @nInterval2 = cast(@nInterval * 2 as varchar(3))
set @nInterval3 = cast(@nInterval * 3 as varchar(3))
set @nInterval4 = cast(@nInterval * 4 as varchar(3))
set @nInterval5 = cast(@nInterval * 5 as varchar(3))
SET @cValue1 = CONVERT(VARCHAR(10),1,110) + ' - ' + CONVERT(VARCHAR(10),@nInterval1,110) + ' Days'
SET @cValue2 = CONVERT(VARCHAR(10),@nInterval1 + 1,110) + ' - ' + CONVERT(VARCHAR(10),@nInterval2,110) + ' Days'
SET @cValue3 = CONVERT(VARCHAR(10),@nInterval2 + 1,110) + ' - ' + CONVERT(VARCHAR(10),@nInterval3,110) + ' Days'
SET @cValue4 = CONVERT(VARCHAR(10),@nInterval3 + 1,110) + ' - ' + CONVERT(VARCHAR(10),@nInterval4,110) + ' Days'
SET @cValue5 = 'Above ' + CONVERT(VARCHAR(10),@nInterval4,110) + ' Days'
create table ##Interval
(
cCompID varchar(20),
nOrder int,
cInterval varchar(20),
cCode varchar(20)
)
---------------------------
--get all the clients
---------------------------
SELECT * INTO ##temp1 FROM
(
select cCode from client_customer where cCode = @cFrom union all
select cGroupCode from client_customer where cCode = @cFrom union all
select cBillingCompany from client_customer where cCode = @cFrom union all
select cArea from client_customer where cCode = @cFrom
)a
---------------------------
--determining the balance of the invoices
---------------------------
SELECT * INTO ##temp2 FROM
(
(
select a.cCompanyID, a.cInvNo, sum(a.nGross) as nSales, 0 as nPaid, 0 as nDebit, 0 as nCredit, 0 as nReturns
from sales a
where a.lCancelled = 0 and a.cPayType<>'Cash'
and a.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, a.cInvNo
)
union all
(
select a.cCompanyID, a.cInvNo, 0 as nSales, sum(a.nApplied) as nPaid, 0 as nDebit, 0 as nCredit, 0 as nReturns
from pr_t a
left outer join pr b on a.cTranNo = b.cTranNo and a.cCompanyID = b.cCompanyID
left outer join sales c on a.cInvNo = c.cInvNo and a.cCompanyID = c.cCompanyID
where b.lCancelled = 0
and c.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, a.cInvNo
)
union all
(
select a.cCompanyID, a.cInvNo, 0 as nSales, 0 as nPaid, sum(a.nDebit) as nDebit, 0 as nCredit, 0 as nReturns
from ar_t a
left outer join ar b on a.cTranNo = b.cTranNo and a.cCompanyID = b.cCompanyID
where b.cType = 'Debit' and b.lCancelled = 0 and b.lApproved = 1
and b.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, a.cInvNo
)
union all
(
select a.cCompanyID, a.cInvNo, 0 as nSales, 0 as nPaid, 0 as nDebit, sum(a.nCredit) as nCredit, 0 as nReturns
from ar_t a
left outer join ar b on a.cTranNo = b.cTranNo and a.cCompanyID = b.cCompanyID
where b.cType = 'Credit' and b.lSalesReturn = 0 and b.lCancelled = 0 and b.lApproved = 1
and b.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, a.cInvNo
)
union all
(
select a.cCompanyID, a.cInvNo,
0 as nSales, 0 as nPaid, 0 as nDebit, 0 as nCredit, sum(a.nCredit) as nReturns
from ar_t a
left outer join ar b on a.cTranNo = b.cTranNo and a.cCompanyID = b.cCompanyID
where b.cType = 'Credit' and b.lSalesReturn = 1 and b.lCancelled = 0 and b.lApproved = 1
and b.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, a.cInvNo
)
)a
-----------------------
--main script for creating the temp ##AR
-----------------------
select a.*, b.cRefNo, b.dRefDate, b.nBeg, b.nEnd, b.nConsumed, b.nConsumedKG, b.nPrice, b.nAmount, b.nVat, b.nWHT, b.nNet,
case when a.nDue <=0 then 'Current'
when a.nDue > 0 and a.nDue <= @nInterval1 then @cValue1
when a.nDue > @nInterval1 and a.nDue <= @nInterval2 then @cValue2
when a.nDue > @nInterval2 and a.nDue <= @nInterval3 then @cValue3
when a.nDue > @nInterval3 and a.nDue <= @nInterval4 then @cValue4
when a.nDue > @nInterval4 then @cValue5
end as cInterval,b.cTenantName into ##AR
from
(
select a.cCompanyID, b.cCode, a.cInvNo, (isnull(sum(a.nSales), 0) - isnull(sum(a.nPaid), 0) + isnull(sum(a.nDebit), 0) - isnull(sum(a.nCredit), 0) - isnull(sum(a.nReturns), 0)) as nBalance,
b.dDate, b.cSMan, b.nGross, b.cTerm, c.cValue, (cast((cast(convert(varchar(20),getdate(),101) as datetime) - b.dDate) as integer) - cast(c.cValue as integer)) as nDue, dateadd(d,cast(c.cValue as integer),b.dDate) as dDueDate
from
(
select * FROM ##temp2 --determining the balance of the invoices
) a
left outer join sales b on a.cInvNo = b.cInvNo and a.cCompanyID = b.cCompanyID
left outer join parameter_user c on b.cTerm = c.cParamName and c.cType = 'TERMS'
where b.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
group by a.cCompanyID, b.cCode, a.cInvNo, b.dDate, b.cSMan, b.nGross, b.cTerm, c.cValue
having (isnull(sum(a.nSales), 0) - isnull(sum(a.nPaid), 0) + isnull(sum(a.nDebit), 0) - isnull(sum(a.nCredit), 0) - isnull(sum(a.nReturns), 0)) > 0
)a
left outer join
(
select a.cCompanyID, a.cInvNo, b.cRefNo, d.dDate as dRefDate,
case when a.cType = 'Meter' then b.nMeterIn
when a.cType = 'Weight' then b.nWeightOut
else 0 end as nBeg,
case when a.cType = 'Meter' then b.nMeterOut
when a.cType = 'Weight' then b.nWeightIn
else 0 end as nEnd, b.nConsumed,
case when a.cType = 'Meter' then b.nConsumedKG
when a.cType = 'Weight' then (b.nWeightOut - b.nWeightIn)
else 0 end as nConsumedKG, b.nPrice, (b.nAmount / 1.12) as nAmount,
(b.nAmount - (b.nAmount / 1.12)) as nVat,
(CASE WHEN e.lEWT=1 THEN ((b.nAmount / 1.12) * e.nEWT/100) ELSE 0 END ) as nWHT, b.nAmount as nNet,f.cTenantName
from sales a left outer join sales_t b on a.cInvNo = b.cInvNo and a.cCompanyID = b.cCompanyID
left outer join item c on b.cItemNo = c.cItemNo and a.cCompanyID = c.cCompanyID
left outer join dr d on d.cDRNo = b.cRefNo
left outer JOIN CLIENT_CUSTOMER e ON a.cCode = e.cCode
left outer JOIN METER_READING_T f ON b.cMRNo = f.cTransNo AND b.nMeterIn = f.nMeterIn
where c.cType <> 'CYLINDER' and a.cType <> 'Invoice' and a.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
union all
select a.cCompanyID, a.cInvNo, d.cDRNo as cRefNo, d.dDate as dRefDate, 0 as nBeg,
0 as nEnd, b.nConsumed, 0 as nConsumedKG, b.nPrice, b.nAmount, 0 as nVat, 0 as nWHT, 0 as nNet,'' as cTenantName
from sales a left outer join sales_t b on a.cInvNo = b.cInvNo and a.cCompanyID = b.cCompanyID
left outer join item c on b.cItemNo = c.cItemNo and a.cCompanyID = c.cCompanyID
left outer join dr d on a.cInvNo = d.cInvNo
where c.cType <> 'CYLINDER' and a.cType = 'Invoice' and d.cDRNo is null and a.cCode in (select * FROM ##temp1) --get all the clients
and a.cCompanyID = @cCompID
)b on a.cInvNo = b.cInvNo and a.cCompanyID = b.cCompanyID
-----------------------
--main script for creating the temp ##Interval
-----------------------
insert into ##Interval
select distinct @cCompID, 1, 'Above 120 Days', cCode from ##AR
insert into ##Interval
select distinct @cCompID, 2, '91 - 120 Days', cCode from ##AR
insert into ##Interval
select distinct @cCompID, 3, '61 - 90 Days', cCode from ##AR
insert into ##Interval
select distinct @cCompID, 4, '31 - 60 Days', cCode from ##AR
insert into ##Interval
select distinct @cCompID, 5, '1 - 30 Days', cCode from ##AR
insert into ##Interval
select distinct @cCompID, 6, 'Current', cCode from ##AR
--------------------------------------
--displaying the result
--------------------------------------
select a.nOrder, a.cInterval, a.cCode, c.cName, (c.cFirstName + ' ' + case when isnull(c.cMiddleInitial,'')='' then '' else c.cMiddleInitial + ' ' end + c.cLastName) as cCustomerName, (case when isnull(c.cBusinessName,'')='' then c.cName else c.cBusinessName end) as cBusinessName,
c.cAddress, c.cLastName, c.cJobTitle, d.cCompanyName, d.cAddress1, d.cAddress2, d.cPhone, d.cfax, d.cEmail, c.cTerm, b.cInvNo, b.nBalance, b.dDate, b.nGross, b.cRefNo, b.dRefDate, b.nBeg, b.nEnd, b.nConsumed, b.nCOnsumedKG,
b.nPrice, b.nAmount, b.nVat, b.nWHT, b.nNet, isnull(e.nTotalPDC,0) as nTotalPDC, f.nTotalAR, f.nTotalPastDue, c.nLimit, @dDateFrom as dStartDate, @dDateTo as dEndDate,--g.cTenantName,
b.cTenantName,(CASE WHEN @cFilter = 'Show Note' THEN 1 ELSE 0 END) AS lNote
from ##Interval a
left outer join ##AR b on a.cInterval = b.cInterval and a.cCode = b.cCode
left outer join client_customer c on a.cCode = c.cCode
left outer join company d on a.cCompID = d.cCompanyID
left outer join
(
select a.cCode, sum(a.nAmount) as nTotalPDC
from checks a
where a.lDeposited=0 and a.cTransType = 'COL' and a.cCode = @cFrom and a.cCompanyID = @cCompID
group by a.cCode
)e on a.cCode=e.cCode
left outer join
(
--select a.cCode, sum(a.nBalance) as nTotalAR, sum(case when a.cInterval <> 'Current' then isnull(a.nBalance,0) else 0 end) as nTotalPastDue
--from ##AR a
--group by a.cCode
SELECT a.cCode,SUM(nTotalAR) AS nTotalAR,SUM(nTotalPastDue) AS nTotalPastDue
FROM
(select distinct a.cCode, (a.nBalance) as nTotalAR,
(case when a.cInterval <> 'Current' then isnull(a.nBalance,0) else 0 end) as nTotalPastDue
from ##AR a) a
GROUP BY a.cCode
)f on a.cCode=f.cCode
order by a.nOrder, a.cCode
drop table ##temp1
drop table ##temp2
drop table ##Interval
drop table ##AR
/*
select * from ##temp1
select * from ##temp2
select * from ##Interval
select * from ##AR
*/
sql server 总是将错误指向这一行
--------------------------------------
--displaying the result
--------------------------------------
select a.nOrder, a.cInterval, a.cCode, c.cName, (c.cFirstName + ' ' + case when isnull(c.cMiddleInitial,'')='' then '' else c.cMiddleInitial + ' ' end + c.cLastName) as cCustomerName, (case when isnull(c.cBusinessName,'')='' then c.cName else c.cBusinessName end) as cBusinessName,
c.cAddress, c.cLastName, c.cJobTitle, d.cCompanyName, d.cAddress1, d.cAddress2, d.cPhone, d.cfax, d.cEmail, c.cTerm, b.cInvNo, b.nBalance, b.dDate, b.nGross, b.cRefNo, b.dRefDate, b.nBeg, b.nEnd, b.nConsumed, b.nCOnsumedKG,
b.nPrice, b.nAmount, b.nVat, b.nWHT, b.nNet, isnull(e.nTotalPDC,0) as nTotalPDC, f.nTotalAR, f.nTotalPastDue, c.nLimit, @dDateFrom as dStartDate, @dDateTo as dEndDate,--g.cTenantName,
b.cTenantName,(CASE WHEN @cFilter = 'Show Note' THEN 1 ELSE 0 END) AS lNote
最佳答案
当您比较/聚合具有不同排序规则的列时,您必须使用 COLLATE
将其中至少一个排序规则与您想要的排序规则保持一致。表达。例如,假设您有一个列 c1
有排序规则Latin1_General_CI_AI
在表中Table1
和一列c2
有排序规则SQL_Latin1_General_CP1_CI_AS
在表中Table2
并且您想将两者结合起来:
SELECT c1 COLLATE SQL_Latin1_General_CP1_CI_AS
FROM Table1
UNION ALL
SELECT c2
FROM Table2;
关于sql - 排序规则冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3800520/
我正在尝试对每个条目有多个值的关联数组进行排序。 例如 [0] => stdClass Object ( [type] => node [sid] => 158 [score] => 0.059600
我在 mysql 中有“日期”列以这种格式保存日期 2014 年 9 月 17 日(日-月-年) 我需要对它们进行升序排序,所以我使用了这个命令: SELECT * FROM table ORDER
我目前正在将 MySQL 存储过程重写为 MS SQL 存储过程,但遇到了问题。 在 MySQL 存储过程中,有一个游标,它根据最近的日期 (effdate) 选择一个值并将其放入变量 (thestt
我想要 gwt r.QuestionId- 排序。但是我得到未排序的 QuestionId 尽管我提到了 QuestionId ASC 的顺序。 SELECT r.QuestionId,
我有一个关于在 scandir 函数中排序的基本问题。到目前为止,我阅读了 POSIX readdir 的手册页,但没有找到有关订购保证的具体信息。 但是当我遍历大目录(无法更改,只读)时,我在多个系
基本上我必须从 SQL 数据库中构建项目列表,但是用户可以选择对 7 个过滤器的任意组合进行过滤,也可以选择要排序的列以及按方向排序。 正如您可以想象的那样,这会以大量不同的组合进行编码,并且数据集非
我有两张 table 。想象第一个是一个目录,包含很多文件(第二个表)。 第二个表(文件)包含修改日期。 现在,我想选择所有目录并按修改日期 ASC 对它们进行排序(因此,最新的修改最上面)。我不想显
我想先根据用户的状态然后根据用户名来排序我的 sql 请求。该状态由 user_type 列设置: 1=活跃,2=不活跃,3=创始人。 我会使用此请求来执行此操作,但它不起作用,因为我想在“活跃”成员
在 C++ 中,我必须实现一个“类似 Excel/Access”(引用)的查询生成器,以允许对数据集进行自定义排序。如果您在 Excel 中使用查询构建器或 SQL 中的“ORDER BY a, b,
我面临这样的挑战: 检索按字段 A 排序的文档 如果字段 B 存在/不为空 . 否则 按字段排序 C. 在 SQL 世界中,我会做两个查询并创建一个 UNION SELECT,但我不知道如何从 Mon
我想对源列表执行以下操作: map 列表 排序 折叠 排序 展开 列表 其中一些方法(例如map和toList)是可链接的,因为它们返回非空对象。但是,sort 方法返回 void,因为它对 List
我制作了一个用于分析 Windows 日志消息编号的脚本。 uniq -c 数字的输出很难预测,因为根据数字的大小会有不同的空白。此时,我手动删除了空白。 这是对消息进行排序和计数的命令: cat n
我有以下词典: mydict1 = {1: 11, 2: 4, 5: 1, 6: 1} mydict2 = {1: 1, 5: 1} 对于它们中的每一个,我想首先按值(降序)排序,然后按键(升序)排序
我刚刚开始使用泛型,目前在对多个字段进行排序时遇到问题。 案例: 我有一个 PeopleList 作为 TObjectList我希望能够通过一次选择一个排序字段,但尽可能保留以前的排序来制作类似 Ex
有没有办法在 sql 中组合 ORDER BY 和 IS NULL 以便我可以在列不为空时按列排序,但如果它为null,按另一列排序? 最佳答案 类似于: ORDER BY CASE WHEN
我有一个包含 2 列“id”和“name”的表。 id 是常规的自动增量索引,name 只是 varchar。 id name 1 john 2 mary 3 pop 4 mary 5 j
场景 网站页面有一个带有分页、过滤、排序功能的表格 View 。 表中的数据是从REST API服务器获取的,数据包含数百万条记录。 数据库 REST API 服务器 Web 服务器 浏览器 问
假设我有一本字典,其中的键(单词)和值(分数)如下: GOD 8 DONG 16 DOG 8 XI 21 我想创建一个字典键(单词)的 NSArray,首先按分数排序,然后按字
如何在 sphinx 上通过 sql 命令选择前 20 行按标题 WEIGHT 排序,接下来 20 行按标题 ASC 排序(总共 40 个结果),但不要给出重复的标题输出。 我尝试了这个 sql 命令
我有一个奇怪的问题,当从 SQLite 数据库中选择信息并根据日期排序时,返回的结果无效。 我的SQL语句是这样的: Select pk from usersDates order by dateti
我是一名优秀的程序员,十分优秀!