且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

PL SQL - 查询问题

更新时间:2022-10-16 22:03:31

以下查询将解决您的问题



 使用 Test_CTE(Column1,FirstColumn2,SecondColumn2,Column2,FirstColumn3,SecondColumn3,Column3)
AS
选择 column1,SUBSTRING(column2, 1 , charindex(' ,',Column2, 1 ) - 1) as FirstColumn2,
SUBSTRING(column2,charindex(' ,',Column2, 1 )+ 1, 10 )SecondColumn2,Column2,
SUBSTRING(column3, 1 ,charindex(' ,',Column3, 1 ) - 1) as FirstColumn3,
SUBSTRING(column3,charindex(' ,',Column3, 1 )+ 1, 10 )SecondColumn3,Column3 来自 tab1

选择 Column1,( CASE WHEN CHARINDEX(FirstColumn2,column3, 1 跨度>)GT; 0 然后 CASE WHEN CHARINDEX(SecondColumn2,column3, 1 )> 0 然后 ' ' else SecondColumn2 + ' 已删除' 结束 else FirstColumn2 + ' 已删除' 结束
+ ' 和' +( CASE WHEN CHARINDEX(FirstColumn3,column2, 1 )> 0 然后 CASE WHEN CHARINDEX(SecondColumn3,column2, 1 跨度>)GT; 0 然后 ' ' else SecondColumn3 + ' 已添加' 结束 else FirstColumn3 + ' 已添加' 结束结果,Column2,column3,CHARINDEX(FirstColumn2,column3, 1 来自 TEst_CTE


Hi,

I am new to Pl/SQl. I have table Test with 3 columns.

Column1 Column2 Column3
-------------------------------------------------

100 CA,OH AR,CA

200 FL,MI MI,NY


So here in the table, when I compare column2 to column3, I have added AR and deleted OH for ID 100. For 200 I have deleted FL and added NY.

How can I find which string I have added in column 3 and which string I have deleted from Column2?

I need answer like ...

From 100, OH deleted and AR added.
From 200, FL deleted and NY added.

Can anyone please help me find out this?

Thank you very much in advance.

What I have tried:

I have tried strcomp function and it gave me whether the string has changed or not. But I need the exact string what has been changed.

Following query will solve your problem

With Test_CTE(Column1,FirstColumn2,SecondColumn2,Column2,FirstColumn3,SecondColumn3,Column3)
AS(
Select column1,SUBSTRING(column2,1, charindex(',',Column2,1)-1) as FirstColumn2,
SUBSTRING(column2,charindex(',',Column2,1)+1,10) SecondColumn2,Column2,
SUBSTRING(column3,1, charindex(',',Column3,1)-1) as FirstColumn3,
SUBSTRING(column3,charindex(',',Column3,1)+1,10) SecondColumn3,Column3 from tab1
)
Select Column1,( CASE WHEN CHARINDEX(FirstColumn2 ,column3,1)> 0 then (CASE WHEN CHARINDEX(SecondColumn2 ,column3,1)> 0 then '' else SecondColumn2  + ' Deleted' end ) else FirstColumn2 + ' Deleted ' end ) 
+ ' and ' + (CASE WHEN CHARINDEX(FirstColumn3 ,column2,1)> 0 then (CASE WHEN CHARINDEX(SecondColumn3 ,column2,1)> 0 then '' else SecondColumn3  + ' Added' end ) else FirstColumn3 + ' Added ' end)  as Result   ,Column2,column3 ,CHARINDEX(FirstColumn2 ,column3,1)from TEst_CTE