Хобрук: Ваш путь к мастерству в программировании

SQL ARRAY: выберите идентификатор из my_table, где значение массива = определенное_значение_массива

Это начальный вопрос, связанный с массивами. Надеюсь ответ прост. Пример взят из Oracle Spatial, но я думаю, что он подходит для всех массивов.

У меня есть этот ВЫБОР:

SELECT
    D.FID
  , D.GEOM.SDO_ELEM_INFO   -- column GEOM contains spatial data
FROM
    my_table D  

Я получаю этот результат:

73035   MDSYS.SDO_ELEM_INFO_ARRAY(1, 2, 1)
73036   MDSYS.SDO_ELEM_INFO_ARRAY(1, 4, 3, 1, 2, 1, 11, 2, 2, 19, 2, 1)
73037   MDSYS.SDO_ELEM_INFO_ARRAY(1, 2, 1)

Теперь я хочу ВЫБРАТЬ все строки, где определено (1,2,1):

SELECT
    D.FID
  , D.GEOM.SDO_ELEM_INFO
FROM
    my_table D
WHERE
-- Pseudo-Code is following
    D.GEOM.SDO_ELEM_INFO is "(1, 2, 1)";

Итак, простыми словами: «массив_из_строки = определенный_массив». Я нашел много информации о IMPLODE, TABLE, COLLECT и т. д. Но как определить предложение для двух массивов?

Спасибо за помощь!


Ответы:


1

Предложение Try IN, вы также можете использовать оба

SELECT
    D.FID
  , D.GEOM.SDO_ELEM_INFO
  FROM
 my_table D
 WHERE
 D.GEOM.SDO_ELEM_INFO in (1, 2, 1) or ( D.GEOM.SDO_ELEM_INFO = 1 or D.GEOM.SDO_ELEM_INFO = 2 or D.GEOM.SDO_ELEM_INFO = 3);
10.06.2020
  • Спасибо, но у меня не работает ORA-00932: inconsistent datatypes: expected NUMBER got MDSYS.SDO_ELEM_INFO_ARRAY 00932. 00000 - "inconsistent datatypes: expected %s got %s" 10.06.2020
  • Удалите одинарные кавычки в запросе. Отредактировал ответ, пожалуйста, используйте его 10.06.2020
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..