Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
16 / 14 / 4
Регистрация: 21.11.2014
Сообщений: 320

Оптимизация функции

18.02.2021, 22:59. Показов 2057. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток, помогите оптимизировать функцию очень надо я только начал изучать это дело!!
Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
CREATE OR REPLACE FUNCTION PUBLIC."fn_AUR_StatementsInsert"(claimsuuid character varying) RETURNS void
    LANGUAGE plpgsql
    AS $$
 DECLARE claimType INTEGER;
BEGIN   
 
claimType = (SELECT "ClaimTypeId"
             FROM "AUR_Claims" 
             WHERE "ID" = claimsuuid::uuid);
            
    IF NOT EXISTS (SELECT "ClaimID" FROM "AUR_CheckListGroups" WHERE "ClaimID" = claimsuuid::uuid)
    
    THEN 
    
    IF (claimType = 1) 
    
    THEN 
    
     INSERT INTO "AUR_CheckListGroups" ("OptionID" , "ClaimID" , "TypeId" )
    SELECT "ID" , claimsuuid::uuid , "GroupTypeID" FROM "AUR_d_CheckListOptions" WHERE "GroupTypeID" = 1 OR "GroupTypeID" = 2;
    
     ELSE 
    INSERT INTO "AUR_CheckListGroups" ("OptionID" , "ClaimID" , "TypeId" )
    SELECT "ID" , claimsuuid::uuid , "GroupTypeID" FROM "AUR_d_CheckListOptions" WHERE "GroupTypeID" = 4;
    END IF; 
   
    END IF;
    
         
END
$$;
Спасибо за ранее

Добавлено через 12 минут
Я понимаю что наверно надо как то селекты объединить так как они отличаются только условием по GroupTypeID но не доходит никак как красиво это сделать
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.02.2021, 22:59
Ответы с готовыми решениями:

Типы оптимизация: черная оптимизация, серая оптимизация и белая оптимизация
Много много лет назад, на заре становления профессии "оптимизатора" в какой то умной книжке был создан миф. Это миф о цветовой индефикации...

Оптимизация кода, функции и методы как параметры функции
Грубо говоря - есть множество циклов которые привязаны к проверочным функциям, поскольку сами по себе тела циклов в принципе идентичны,...

Оптимизация функции
Здравствуйте, есть программа которая ищет самые короткие пути из 0 узла до всех остальных узлов в графике, по алгоритму Дейкстры с...

4
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
18.02.2021, 23:49
Лучший ответ Сообщение было отмечено Nightwalker как решение

Решение

Если хотите свернуть два запроса в один по условия GroupTypeId, то можно известные значения типов формировать в отдельном массиве и проверять на наличие GroupTypeId в этом массиве операторами вида ANY

Тогда получится что-то типа

Oracle 11 SQL
1
2
3
4
5
6
7
IF (ClaimType = 1) THEN
type_array := ARRAY[1,2];
ELSE
type_array := ARRAY[4];
END IF;
INSERT INTO "AUR_CheckListGroups" ("OptionID" , "ClaimID" , "TypeId" )
SELECT "ID" , claimsuuid::uuid , "GroupTypeID" FROM "AUR_d_CheckListOptions" WHERE "GroupTypeID" = ANY(type_array);
Также можно внести определение claimType под условие IF NOT EXISTS.
1
16 / 14 / 4
Регистрация: 21.11.2014
Сообщений: 320
19.02.2021, 00:05  [ТС]
Хммм и незнал о таких решениях спасибо, но это не сложнее конструкция ??? или мне так кажется ?

Добавлено через 4 минуты
ну в смысле использывание массивов ??? хотя такой подход довольно красивый!
0
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
19.02.2021, 08:53
слово "сложнее" тут не подходит, не в сложности дело.

тут важнее, сколько этот SELECT будет выполняться, какой план выберет база для его выполнения.
Все поисковые операции так или иначе должны быть связаны с каким-либо индексом - единственный механизм ускорения поиска.
Когда у вас 10ки-100ни записей, то их быстрее перебрать последовательно в цикле и найти те, которые удовлетворяют условию WHERE. Когда записей становится 1000чи и далее, то реально помагают только индексы.
Поэтом в процедуре вы можете написать и оптимизировать код как угодно, значительно быстрее выполнение функции от этого не станет.
А вот сколько будет выполнять отдельно взятый SELECT это уже важно.

Еще тут уместно говорить о понятности кода с целью его последующего поддержания и расширения.
Напишите понятно, значит через полгода сами посмотрите на функцию и сразу поймете и вспоните суть.
Напишите мудрено, значит будете сами разбираться и другой человек, который посмотрит ваш код, также будет страдать.
1
16 / 14 / 4
Регистрация: 21.11.2014
Сообщений: 320
19.02.2021, 10:12  [ТС]
Понял,спасибо за помощь!!! Тема закрыта!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.02.2021, 10:12
Помогаю со студенческими работами здесь

Оптимизация функции
Просто ради интереса собрал функцию на ассемблере которая создаёт список всех файлов, в данном случае на диске С .Только пока получилось...

Оптимизация функции
Всем привет, нужна помощь в написании курсовой работы. Вот такое задание: Расчеты сделанные вручную, нужно написать код для 1 и 2...

Оптимизация функции
Всем привет. Нужна ваша помощь, чтобы исправить ошибку. Буду рад любой помощи. https://glot.io/snippets/er2muuidny

Оптимизация функции
Помогите разобраться с кодом, в конце что то не то выводит. мне нужно найти ri, r2, h, S clc close all clear all %Начальная...

Оптимизация функции
$(document).ready(function() { $('#info1').on('click', () => { $('#info').html('Какой то текст'); }); }); ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru