Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 182
  • Last Modified:

Using Like

I'm trying to use "Like" like below but this only looks for exact matches. How can I do this?

Note that F_Alert table has no keys related to the other table.
select * from f_alert where 
   criteria like (select Addressee from LAddress lc
                      inner join customeraddress mca on mca.addressid=lc.id  where mca.customerid = '123')

Open in new window

0
Camillia
Asked:
Camillia
1 Solution
 
EspavoCommented:
Try this:
select * from f_alert where 
   criteria like '%(select Addressee from LAddress lc
                      inner join customeraddress mca on mca.addressid=lc.id  where mca.customerid = '123')%'

Open in new window

0
 
Aneesh RetnakaranDatabase AdministratorCommented:

select *
from f_alert f
where exists
(select null
from LAddress lc
inner join customeraddress mca on mca.addressid=lc.id
where mca.customerid = '123' AND f.criteria like '%'+Addressee+'%')
0
 
8080_DiverCommented:
Try the following two options.  Using LIKE is bad enough without compounding things with an EXISTS. ;-)

Option 1:
 
SELECT F.* 
FROM f_alert F
INNER JOIN LAddress A
ON F.criteria = A.Addressee
INNER JOIN  customeraddress C
ON C.addressid=A.id  
AND C.customerid LIKE '%' + '123' + '%';
 
Option 2:
SELECT F.* 
FROM f_alert F
INNER JOIN LAddress A
ON F.criteria = A.Addressee
INNER JOIN  customeraddress C
ON C.addressid=A.id  
WHERE C.customerid LIKE '%' + '123' + '%';

Open in new window

0
Prepare for your VMware VCP6-DCV exam.

Josh Coen and Jason Langer have prepared the latest edition of VCP study guide. Both authors have been working in the IT field for more than a decade, and both hold VMware certifications. This 163-page guide covers all 10 of the exam blueprint sections.

 
CamilliaAuthor Commented:
let me see. Thanks. Yeah, like is not good.
0
 
8080_DiverCommented:
LIKE is Not A Good THing . . . unless it is the only way to get there from here. ;-)
However, when you use LIKE, you just have to be aware that you have just agreed to have potentially very poor performance and, if you are playing with enough data, time outs. ;-)
Where I work, there is an application that may wind up using up to 5 instances of LIKE '%whatever%' on tables with millions of rows . . . and they keep asking me to provide indexes to solve their performance issues. ;-)
0
 
CamilliaAuthor Commented:
Fraud_alert table has a row with column =330.  LocAddress has a column=33092

It should bring back that "330" row but it doesnt:

select * 
from fraud_alert f 
where exists 
(select null 
from LocAddress lc 
inner join memcustomeraddress mca on mca.addressid=lc.id 
where mca.customerid = '123' AND 
(f.criteria like '%' + PostalCode + '%' OR f.criteria like '%'+Addressee+'%' OR f.criteria like '%'+ Address1 + '%' )
 
)

Open in new window

0
 
8080_DiverCommented:
You've got your LIKEs cross wired.  (And I still done't like the EXISTS approach but I don't have time to alter that part. ;-)
select * 
from fraud_alert f 
where exists 
(select null 
from LocAddress lc 
inner join memcustomeraddress mca on mca.addressid=lc.id 
where mca.customerid = '123' AND 
(PostalCode like '%' + f.criteria + '%' OR Addressee like '%'+f.criteria+'%' OR Address1 like '%'+ f.criteria + '%' )
 
)

Open in new window

0
 
8080_DiverCommented:
On second thought, it didn't take too long: ;-)
SELECT f.* 
FROM fraud_alert f 
INNER JOIN 
(
 SELECT PostalCode,
        Addressee,
        Address1 
FROM LocAddress lc 
INNER JOIN memcustomeraddress mca 
   ON mca.addressid=lc.id 
WHERE  mca.customerid = '123'
) Z
ON (Z.PostalCode like '%' + f.criteria + '%' ) OR 
   (Z.Addressee like '%'+f.criteria+'%' ) OR 
   (Address1 like '%'+ f.criteria + '%' );
 

Open in new window

0
 
CamilliaAuthor Commented:
8080: your last one worked. Let me try one more thing and will post back
0

Featured Post

Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now