Как искать точное слово в скобках с помощью рельсов?

Я хочу знать, как найти точное слово в скобках, а не слова, включающие искомое слово. Например, если я пытаюсь найти угарный газ [CO] и если я ищу CO, я хочу, чтобы в моих результатах отображался только угарный газ [CO], а не двуокись углерода [CO2].

До сих пор у меня есть,

where("lower(gas_analyte) LIKE lower(?)", "%#{gas_analyte}%")

Вы можете использовать регулярное выражение в запросах ActiveRecord. В вашем примере вы можете сделать ` .where("gas_analyte ~* ?", '[CO]$') ` SO неправильно форматирует мое регулярное выражение, вы можете увидеть его здесь regexper.com/#%5C%5BCO%5C%5D%24 К сожалению, '\[#{gas_analyte}\]$' у меня не сработало, это то, что вам придется искать и проверять. Поэтому я добавил это как комментарий

sameera207 12.07.2019 07:13
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
1
53
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Не используйте подобный запрос в этом случае! Вы можете использовать условие куда, которое является результатом фильтрации текущего отношения в соответствии с условиями в аргументах. он вернет точные параметры, соответствующие записям.

where(gas_analyte:gas_analyte)

Мне нравиться возвращает что-то, совпадающее с записями ваших параметров.

Спасибо, но это не работает. Я думаю, это потому, что я только пытаюсь получить содержимое внутри скобки

DLIM7 16.07.2019 04:53

Ой, извините... не могли бы вы показать мне свои записи в таблице? И чего вы пытаетесь достичь?

Giridharan 16.07.2019 04:59

Sensors = Sensors.joins(setup_variable: :gas_analytes).where("lower(gas_analytes.gas)[/[(.*?) ‌​3;/, 1] КАК ниже(?)", "#{gas_analyte}" ). Это то, что у меня есть, но это не работает. Итак, я хочу посмотреть, соответствует ли искомый контент содержимому в скобках, выполнив [/[(.*?)]/, 1], но это не работает. Итак, есть ли что-то подобное, что я могу сделать только для соответствия содержимому в скобках.

DLIM7 17.07.2019 01:57

@Gases = ['Двуокись углерода [CO2]','Этанол [CH3CH2OH]', 'Угарный газ [CO]'] — это переменная, содержащая газы.

DLIM7 17.07.2019 01:59

Другие вопросы по теме