Gå til innhold

Query: sammenligne tabeller (WHERE LIKE)


Anbefalte innlegg

Har to tabeller i en database.

 

Den ene tabellen mail er en mailingliste som inneholder bla kolonnen email

 

Den andre tabellen unwanted er en liste hvor man kan legge inn mail adresser eller domenenavn (søkeord) som man ønsker å fjerne fra mailinglisten. kolonnen heter searchword

 

Følgene query fungerer utmerket og er meget rask:

 

"UPDATE mail SET status=? WHERE mail='unwanted.searchword'"

 

Men denne søker kun etter innhold som er identisk med innholdet i searchword kolonnen. Jeg ønsker at den skal finne alt som innholder innholdet i searchword.

 

Slik:

 

"UPDATE mail SET status=? WHERE mail LIKE '%unwanted.searchword%'"

 

Men det fungerer ikke. Hvorfor? og hvordan skal det gjøres?

 

Noen som vet?

Lenke til kommentar
Videoannonse
Annonse

En del informasjon rundt problemstillingen mangler, og vi har bare delvis tabelldefinisjon. Det du ønsker å gjøre er vel noe i retning av:

 

UPDATE mail SET status='deny' FROM mail m inner join unwanted u on (m.sender like '%'+u.searchword+'%')

 

Ellers skal det nevnes at dette vil være tyngre operasjon enn du kanskje ønsker dersom det blir mye data, så da ville jeg sett på muligheten av å bruke fulltekstsøk, hvis databasemotoren din støtter det.

Endret av roac
Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
  • Hvem er aktive   0 medlemmer

    • Ingen innloggede medlemmer aktive
×
×
  • Opprett ny...