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

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

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

18 ответов

68 просмотров

Можно посмотреть 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
Уберите все агрегаты и получите то что хотите.

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта