I have a table with the following values:
ID NAME ADDRESS
1 Bob Super stree1 here goes
2 Alice stree100 here goes
3 Clark Fast left stree1005
4 Magie Right stree1580 here goes
I need to make a query using LIKE and get only the row having stree1 (in this case only get the one with ID=1) and I use the following query:
select * from table t1 WHERE t1.ADDRESS LIKE '%stree1%';
But the problem is that I get all rows as each of them contains stree1 plus some char/number after.
I have found out that I can use REGEXP_LIKE as I am using oracle, what would be the proper regex to use in:
select * from table t1 WHERE regexp_like(t1.ADDRESS ,'stree1');
I would think that this would be the reg-ex you are seeking:
If you want to, you can further simplify this to:
That is, ‘stree1’ is not followed by a word character (i.e., is followed by space/punctuation/etc…) or ‘stree1’ appears at the end of the string. Of course there are many other ways to do the same thing, including word boundaries ‘stree1\b’, expecting particular characters after the 1 in stree1 (e.g., a white-space with ‘stree1\s’), etc…