169 похожих чатов

Привет, каким образом можно посмотреть все данные, затрагиваемые запросом? К

примеру есть запрос, который использует агрегатную функцию, и мне нужно посмотреть все строки, для которых она применяется. В случае простых запросов я конечно могу просто изменить его текст, но проблема в том, что приходится работать с хранимками по 500-2000 строк sql.

18 ответов

18 просмотров

Можно посмотреть sys.syscomments лайком по полю text

а нафига тебе их глядеть?

Gopneg
ты вопрос-то читал?

Прошу пардону, ответил на более осмысленную версию вопроса.

Написать другой запрос, без агрегации, выполнить

Я сейчас пишу юнит тесты для перенесенных хп на linq, и мне необходимы данные в качестве тестового набора. Заполнять руками десятки таблиц, и вникать в логику, которую к тому же писал не я, нету ни времени ни желания.

Ilya Zviagin
Написать другой запрос, без агрегации, выполнить

С простыми запросами я так и делаю, но есть запросы с кучей подзапросов и соединений, и вызовов других функций, которые бывают и по 500 и по 1000 строк кода.

Ilya Zviagin
всё равно рецепт тот же

Я поэтому и спросил, может есть какой-то инструмент профилирования, способный быстро и эффективно решить эту проблему.

Все кортежи к которым идёт обращение(все что в output + все предикаты, в том числе участвующие в соединениях). Также учтите, сиквел не читает строками, он читает страницами. Некоторые данные также могут читаться несколько раз, как пример spool table. Хоть это и временная структура , но количество чтений/записи она добавит. Ну и конечно же работа с tempdb. Вообще не корректно поставленный вопрос имхо.

Gopneg
а всю базу заюзать низя?

Нет, нам запрещено использовать базу в юнит тестах.

ꀀꁰꁵꁴꁩꁮꀊ ꃿꃫꁄꁃꃿꃫꁯꁏꃽꀿꃛ
Нет, нам запрещено использовать базу в юнит тестах...

не работай с идиотами хранимки переписали на линк, заставили негра тестировать бд без бд все бы хорошо если не быть этим негром

Dmitriy Ivanov
Все кортежи к которым идёт обращение(все что в out...

В общем как я понял, это невозможно. Спасибо.

ꀀꁰꁵꁴꁩꁮꀊ ꃿꃫꁄꁃꃿꃫꁯꁏꃽꀿꃛ
В общем как я понял, это невозможно. Спасибо.

Возможно, но не понятно , что конкретно нужно получить как результат.

Dmitriy Ivanov
Возможно, но не понятно , что конкретно нужно полу...

Предположим есть 2 таблицы: CREATE TABLE Rabbits (   Id INTEGER,   Name VARCHAR(255),   Age INTEGER,   Weight DOUBLE,   UnitId INTEGER,   FOREIGN KEY (UnitId) REFERENCES Units(Id) ); CREATE TABLE Units (   Id INTEGER,   Name VARCHAR(255) ); Я пишу для них запрос по типу select Age, sum(weight) as TotalWeight from Rabbits join Units on UnitId = Units.Id where Units.Name = 'Unit1' group by Age И мне необходимо получить данные, над которыми производился данный запрос. Они будут эквивалентны результату выполнения следующих запросов: select * from Units where Units.Name = 'Unit1' select Age, Weight, UnitId from Rabbits where UnitId = 1 На текущем примере это не составляет труда, но когда запрос содержит десятки таблиц с кучей jon'ов и подзапросов, это составляет большую проблему, как все это декомпозировать без нарушения логики.

Dmitriy Ivanov
Уберите все агрегаты и получите то что хотите.

Это и так понятно. Проблема в том, что те запросы, над которыми я работаю, очень сложны для этого.

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
думаешь я не смогу также сделать? мне это просто не удобно
int 💳 𝙖𝙞𝙧 𝙗𝙞𝙜 𝙗𝙤𝙗 🔫 check bio / spam block / AFK / nohello.com / GMT+3
9
Карта сайта