Я хочу найти всех пользователей с кириллическими именами. Как я могу это сделать с помощью ActiveRecord?
Решение без ActiveRecord находится здесь: User.all.select{ |user| user.name.match(/\p{Cyrillic}/) }. К сожалению, regexp /\p{Cyrillic}/ не работает с sql.
ОБНОВЛЕНИЕ: из обсуждения ниже я понимаю, что мне нужны решения для Postgres и MySQL.
Для postgres это может быть SELECT * FROM "items" WHERE (title SIMILAR TO '%[\u0410-\u044f]%')
из Найти все строки, используя некоторый диапазон Unicode (например, символы кириллицы) с PostgreSQL?
@JagdeepSingh Это точно не дубликат этой ссылки. Автор вообще не спрашивал, «как использовать Regexp в SQL».
Алекс, вам нужно добавить свою БД в теги, потому что ответ зависит от БД. Т.е. для Postgresql - stackoverflow.com/questions/19789604/…
@PavelMikhailyuk благодарит за решение Postgres. Я хотел бы получить ответ, не связанный с БД, который можно было бы использовать и для MySQL и Postgres;)
@JagdeepSingh спасибо за ссылку, но речь идет только о регулярном выражении в запросе ActiveRecord. Мне нужен конкретный.
Алекс, в SQL нет стандарта регулярных выражений. Каждая БД реализует это своими собственными ключевыми словами и (что еще хуже) собственными библиотеками регулярных выражений stackoverflow.com/questions/18780194/…
И даже решение из примера Postrge не идеально, так как зависит от строковых данных encoding, которые могут отличаться.






Возможный дубликат stackoverflow.com/questions/19777720/…