Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
25 / 26 / 5
Регистрация: 27.10.2016
Сообщений: 245
.NET 4.x

Получить готовый SQL запрос после добавления параметров

28.01.2019, 15:51. Показов 1844. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, допустим есть такое:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
using (SqlConnection connection = DBServerUtils.GetDBConnection())
            {
                try
                {
                    connection.Open();
                    string cSql = string.Format("INSERT INTO Paf VALUES (@idT, @fname, @name)");
                    using (SqlCommand command = new SqlCommand(cSql, connection))
                    {
 
 
                        SqlParameter idT = new SqlParameter("@idT", SqlDbType.Int);
                        .......
                        idT.Value = textbox1.text;
                        ....
                       command.Parameters.Add(idT);
                       ......
                       SqlDataReader reader = command.ExecuteReader();
                 }
                 catch{}
Как после или до выполнения команды ExecuteReader(), получить получившийся запрос?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.01.2019, 15:51
Ответы с готовыми решениями:

Как выполнить свой sql запрос после добавления данных в БД через админку?
Всем привет. Такой вопрос: Есть админка django suit, есть модель с полями, как выполнить свой sql запрос после добавления данных в бд...

Запустить готовый SQL запрос в WinForms
Есть готовая база данных на сервере SQL, есть готовые запросы, сохраненные отдельными файлами. Как запустить эти файлы запросов в...

Связать готовый запрос в SQl c Delphi
Добрый день! В Microsoft SQL Server Management Studio находятся все базы данных(и все таблицы) с главного сервера.Там же написан sql...

12
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
28.01.2019, 15:56
Цитата Сообщение от Jake Morgan Посмотреть сообщение
получить получившийся запрос?
Вы его прописываете в переменной cSql

Добавлено через 15 секунд
воспользуйтесь отладчиком и увидите
0
25 / 26 / 5
Регистрация: 27.10.2016
Сообщений: 245
28.01.2019, 16:01  [ТС]
Почтальон, да, я задаю его в cSql, но строка будет INSERT INTO Paf VALUES (@idT, @fname, @name)
А мне нужна с уже подставленными значениями

Добавлено через 3 минуты
по сути мне нужен изменённый cSql, т.е к примеру, если вывести MessageBox.Show(csql) он покажет мне это: INSERT INTO Paf VALUES (@idT, @fname, @name), а мне нужно чтобы показал к примеру INSERT INTO Paf VALUES (10, Морозов, Михаил), чтобы @idT, @fname, @name уже были заменены параметрами
0
24 / 24 / 10
Регистрация: 02.09.2014
Сообщений: 137
28.01.2019, 18:04
Цитата Сообщение от Jake Morgan Посмотреть сообщение
по сути мне нужен изменённый cSql, т.е к примеру, если вывести MessageBox.Show(csql) он покажет мне это: INSERT INTO Paf VALUES (@idT, @fname, @name), а мне нужно чтобы показал к примеру INSERT INTO Paf VALUES (10, Морозов, Михаил), чтобы @idT, @fname, @name уже были заменены параметрами
Jake Morgan, а зачем?
0
25 / 26 / 5
Регистрация: 27.10.2016
Сообщений: 245
29.01.2019, 02:13  [ТС]
Luce, Log
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
29.01.2019, 10:18
Code
1
string.Format("INSERT INTO Paf VALUES ({0},{1},{2})",idT,someVal1,someVal2)
не предлагать?
0
25 / 26 / 5
Регистрация: 27.10.2016
Сообщений: 245
29.01.2019, 10:52  [ТС]
pincet, нет(

Добавлено через 29 минут
Ответ, вдруг кому нужно:
C#
1
2
3
string Q=Cmd.CommandText; 
foreach (SqlParameter P in Cmd.Parameters) 
Q=Q.Replace(P.ParameterName, P.Value.ToString());
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
29.01.2019, 12:02
да, забивать гвозди микроскопом это пять
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18285 / 14208 / 5368
Регистрация: 17.03.2014
Сообщений: 28,887
Записей в блоге: 1
29.01.2019, 15:22
Jake Morgan, я бы выводил в лог отдельно запрос как есть, а отдельно список параметров и их значений.
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
29.01.2019, 15:29
Цитата Сообщение от OwenGlendower Посмотреть сообщение
я бы выводил в лог отдельно запрос как есть, а отдельно список параметров и их значений.
а смысл? если только смотритель лога не имеет доступа к коду. имхо тогда пихать в лог текст скрипта запроса и текст скрипта со значениями параметров
однако, решать ТСу
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18285 / 14208 / 5368
Регистрация: 17.03.2014
Сообщений: 28,887
Записей в блоге: 1
29.01.2019, 15:44
pincet, чтобы видеть реальный запрос, который можно найти в коде. Тем более что прямая замена параметра на его значение даст синтаксически неверный запрос. Там не будет кавычек вокруг строк, формат дат будет вероятно не тот. Также в параметрах есть другая полезная информация: тип параметра, максимальная длина, допускается ли null.
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
29.01.2019, 15:55
Цитата Сообщение от OwenGlendower Посмотреть сообщение
чтобы видеть реальный запрос, который можно найти в коде
Цитата Сообщение от pincet Посмотреть сообщение
имхо тогда пихать в лог текст скрипта запроса
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Там не будет кавычек вокруг строк, формат дат будет вероятно не тот. Также в параметрах есть другая полезная информация: тип параметра, максимальная длина, допускается ли null.
за правильность синтаксиса SQL отвечает только писатель кода. Формат даты - это на совести также писателя (с оглядкой на поставщика данных)
А зачем в логе тип параметра и вся остальная шелуха?
IMHO задача за уши притянута
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18285 / 14208 / 5368
Регистрация: 17.03.2014
Сообщений: 28,887
Записей в блоге: 1
29.01.2019, 16:21
Цитата Сообщение от pincet Посмотреть сообщение
за правильность синтаксиса SQL отвечает только писатель кода
Само собой. Я имел в виду запрос который получится после прямой замены имени параметра на значение как это сделал ТС
Цитата Сообщение от Jake Morgan Посмотреть сообщение
C#
1
2
3
string Q=Cmd.CommandText;
foreach (SqlParameter P in Cmd.Parameters)
Q=Q.Replace(P.ParameterName, P.Value.ToString());
Про формат даты тоже для этого примера я писал. В итоге мы получим неверный запрос. Понятно что это несложно исправить. Вопрос нужно ли.

Цитата Сообщение от pincet Посмотреть сообщение
А зачем в логе тип параметра и вся остальная шелуха?
Кому-то шелуха, а кому-то ценная информация. Я всего-лишь предложил, а решать ТСу.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.01.2019, 16:21
Помогаю со студенческими работами здесь

Как получить id после добавления записи?
Вот код где добавляю запись и хочу получить айди. Сердце чует что-то не то делаю:wall: Подскажите, где ошибка, код добавленной записи...

Как получить id после добавления записи средствами ADO
Здравствуйте, помогите разобраться: после добавления в базу данных записи (TableAdapter.Insert) мне нужно получить id этой записи. Как это...

Не получается получить PrimaryKey после добавления данных в таблицу
int primaryKey; using (SqlConnection sqlCon = new SqlConnection(connection)) { ...

Ругается на SQL запрос: отсутствует значение для одного или неск. требуемых параметров
Добрый день. Не могу отыскать проблему, ругается что отсутствуют параметры, уже не знаю куда смотреть и что исправить. Вот собственно код: ...

Как получить значение поля счетчика после добавления через rst.AddNew ?
Добрый день всем. Есть таблица, в ней, само собой, первое поле - Код (счетчик), и несколько других. Через код VBA добавляю в данную...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru