日期:2014-05-18  浏览次数:20485 次

求解一个疑难的SQL语句
CREATE TABLE ORDERS
(
 OrderID VARCHAR(50),
 MemberID VARCHAR(100),
 CREATEON DATETIME
)

INSERT INTO Orders
SELECT 'FP1','1','2012-05-12' UNION
SELECT 'FP2','1','2012-05-13' UNION
SELECT 'FP3','1','2012-05-14' UNION
SELECT 'FP4','2' ,'2012-05-12'


CREATE TABLE OrderShipping
(
  OrderID VARCHAR(50) ,
  Address1 VARCHAR(50),
  Address2 VARCHAR(50),
  CountryName VARCHAR(50),
  ProviNce VARCHAR(50)
)

INSERT INTO OrderShipping
SELECT 'FP1', '金华1','金华','中国1','浙江' UNION
SELECT 'FP2', '金华1','金华','中国1','浙江' UNION
SELECT 'FP3', '金华2','金华','中国2','浙江' UNION
SELECT 'FP4', '深圳','深圳','中国2','广东'  

需求实现功能:已知Orders表里面的MemberID 是传进来的参数 判断如果memberid 对应的 orderid有多条则做逻辑处理 
得出来的就是 memberid =1 的 三条记录 对应OrderShipping (订单发货信息表) 三条明细 找出最后一条和倒数第二条判断地址是否有变更如果有则做处理

SQL怎么写啊,疑惑:如何根据memberid查出多条的订单号再去关联订单发货表,再拿最后一条记录去和倒数第二条做比较呀 随便一个信息不匹配的都为异常
求高手帮忙下。

结果应该是 ordershipping 表里面的 FP3 和FP2做比较 得出来结果为地址不一致为异常


------解决方案--------------------
SQL code

CREATE TABLE ORDERS
(
 OrderID VARCHAR(50),
 MemberID VARCHAR(100),
 CREATEON DATETIME
)

INSERT INTO Orders
SELECT 'FP1','1','2012-05-12' UNION
SELECT 'FP2','1','2012-05-13' UNION
SELECT 'FP3','1','2012-05-14' UNION
SELECT 'FP4','2' ,'2012-05-12'


CREATE TABLE OrderShipping
(
  OrderID VARCHAR(50) ,
  Address1 VARCHAR(50),
  Address2 VARCHAR(50),
  CountryName VARCHAR(50),
  ProviNce VARCHAR(50)
)

INSERT INTO OrderShipping
SELECT 'FP1', '金华1','金华','中国1','浙江' UNION
SELECT 'FP2', '金华1','金华','中国1','浙江' UNION
SELECT 'FP3', '金华2','金华','中国2','浙江' UNION
SELECT 'FP4', '深圳','深圳','中国2','广东'   

if OBJECT_ID('pro_test')is not null
drop proc pro_test
go
create proc pro_test(@menberid int)
as
select px=ROW_NUMBER()over(order by getdate()),
t.OrderID,n.Address1,n.Address2,n.CountryName,n.ProviNce into #test
 from(select 
OrderID,MemberID,count(OrderID)over(partition by MemberID) as Total
from ORDERS)t
inner join OrderShipping n
on t.OrderID=n.OrderID
where t.Total>=2 and t.MemberID=@menberid
declare @px int
select @px=max(px) from #test
if (select ProviNce from #test where px=@px)
   <>(select ProviNce from #test where px=@px-1)
print '地址不一致为异常'
else 
print '地址一致为正常'
go
exec pro_test 1
/*
地址一致为正常
*/

------解决方案--------------------
SQL code

CREATE TABLE ORDERS
(
 OrderID VARCHAR(50),
 MemberID VARCHAR(100),
 CREATEON DATETIME
)

INSERT INTO Orders
SELECT 'FP1','1','2012-05-12' UNION
SELECT 'FP2','1','2012-05-13' UNION
SELECT 'FP3','1','2012-05-14' UNION
SELECT 'FP4','2' ,'2012-05-12'


CREATE TABLE OrderShipping
(
  OrderID VARCHAR(50) ,
  Address1 VARCHAR(50),
  Address2 VARCHAR(50),
  CountryName VARCHAR(50),
  ProviNce VARCHAR(50)
)

INSERT INTO OrderShipping
SELECT 'FP1', '金华1','金华','中国1','浙江' UNION
SELECT 'FP2', '金华1','金华','中国1','浙江' UNION
SELECT 'FP3', '金华2','金华','中国2','浙江' UNION
SELECT 'FP4', '深圳','深圳','中国2','广东'   

if OBJECT_ID('pro_test')is not null
drop proc pro_test
go
create proc pro_test(@menberid int)
as
select px=ROW_NUMBER()over(order by getdate()),
t.OrderID,n.Address1,n.Address2,n.CountryName,n.ProviNce into #test
 from(select 
OrderID,MemberID,count(OrderID)over(partition by MemberID) as Total
from ORDERS)t
inner join OrderShipping n
on t.OrderID=n.OrderID
where t.Total>=2 and t.MemberID=@menberid
declare @px int
select @px=max(px) from #test
if (select CountryName+ProviNce+Address1+Address2 from #test where px=@px)
   <>(select CountryName+ProviNce+Address1+Address2 from #test where px=@px-1)

print '地址不一致为异常'
else 
print '地址一致为正常'
go
exec pro_test 1
/*
地址不一致为异常
*/


--我只是比较了最后一个Province,没比较全部地址,这下应该对了吧

------解决方案--------------------
探讨