Nano Hash - криптовалюты, майнинг, программирование

Как использовать глобальную переменную в хранимой процедуре оракула для запроса

Мне были предоставлены глобальные переменные & S_NAME, & R_ID, которые я хочу использовать в хранимой процедуре оракула для запроса курсора для таблицы kpi_log. Эта глобальная переменная извлечет все необходимые входные значения из таблицы kpi_chk, где у меня есть имя столбца и идентификатор, и передаст их в таблицу kpi_log. Раньше я не использовал глобальную переменную и даже не знаю, как ее использовать.

CREATE OR REPLACE PROCEDURE TEST_CHK  
(IN_L_ID OUT NUMBER)   
AS   

CURSOR STA_CHECK IS  
Select NAME, ID FROM KPI_LOG where NAME = [here i have to use gloabal variable] and ID = [here i have to use gloabal variable];  


BEGIN    

... 


END TEST_CHK;  

  • Если у вас есть пакет, объявите переменную внутри спецификации пакета. Он будет доступен для всех процедур ИЛИ вы можете указать их в качестве входных параметров @andrew 11.01.2018
  • так как мне определить это в запросе в моей процедуре? я имею в виду синтаксис использования глобальной переменной в запросе 11.01.2018
  • У вас есть пакет? Затем объявите его как обычную переменную 11.01.2018
  • ваша переменная будет глобальной, если вы объявите ее внутри спецификации пакета 11.01.2018
  • на самом деле пакет находится в производственной базе данных, поэтому я не могу его увидеть, но я полагаю, что эта глобальная переменная была определена. Не могли бы вы привести пример, как его использовать. Это действительно сбивает меня с толку. 11.01.2018
  • да, я это понял, но как я могу использовать эту переменную в своем запросе на выборку? Например, &S_NAME, &R_ID у меня есть эта глобальная переменная. Нужно ли мне назначать «&» при его использовании, и нужно ли мне объявлять обычную переменную и присваивать ей какое-либо значение? 11.01.2018
  • попробуйте ответ, если у вас есть значения в вашей переменной 11.01.2018

Ответы:


1

Если у вас есть значение в переменных, возьмите его в качестве входного параметра

CREATE OR REPLACE PROCEDURE TEST_CHK  
(IN_L_ID OUT NUMBER, S_NAME VARCHAR2(50),R_ID VARCHAR2(50) )   
AS   

CURSOR STA_CHECK IS  
Select NAME, ID FROM KPI_LOG where NAME = S_NAME  and ID =R_ID;  

BEGIN    

... 


END TEST_CHK; 
11.01.2018
  • только небольшой вопрос, могу ли я объявить это также? СОЗДАТЬ ИЛИ ЗАМЕНИТЬ ПРОЦЕДУРУ TEST_CHK (IN_L_ID OUT NUMBER) AS S_NAME VARCHAR2(50); R_ID VARCHAR2 (50); CURSOR STA_CHECK IS Выберите ИМЯ, ID ИЗ KPI_LOG, где ИМЯ = S_NAME и ID = R_ID; НАЧАЛО... КОНЕЦ TEST_CHK 11.01.2018
  • Да можно, попробуй! 11.01.2018
  • @Andrew Да, вы можете просто обратиться к переменной по имени. Если он находится в другом пакете, вам нужно будет указать имя пакета, используя точечную запись, например. otherpackage.somevar. Для переменных/констант/параметров PL/SQL нет префиксного символа, такого как @ или &. 11.01.2018
  • только небольшой вопрос, если я создаю процедуру, не определенную в спецификации пакета или теле пакета, могу ли я использовать эту глобальную переменную с точечной нотацией в моей процедуре? 11.01.2018
  • Да @Эндрю. Как было предложено, используйте packagename.variablename 11.01.2018
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

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

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..