|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
||||||
Что не так в SQL запросе?19.01.2020, 19:00. Показов 876. Ответов 14
Метки нет (Все метки)
Задача программы - прочитать первые 4 байта из бинарника и записать их в столбцы таблицы SQL
Столбцы, в таблице SQL, предназначающиеся для байтов, имеют тип binary Байты, прочитанные из бинарника, записываются в массив "byte[] hxVls = new byte[4];" Но VS ругается: Additional information: Implicit conversion from data type varchar to binary is not allowed. Use the CONVERT function to run this query. Каким образом байты из байтового массива становятся varchar понять не могу... Чего ему от меня нужно? Строка запроса: string query = "INSERT INTO myTable (b1, b2, b3, b4, path, animName) VALUES ('" + hxVls[0] + "','" + hxVls[1] + "','" + hxVls[2] + "','" + hxVls[3] + "','" + allFiles[i] + "','" + cutPath + "')"; Собственно весь код: Кликните здесь для просмотра всего текста
0
|
||||||
| 19.01.2020, 19:00 | |
|
Ответы с готовыми решениями:
14
Что не так в запросе? Что не так в запросе? Что не так в запросе? |
|
37 / 35 / 7
Регистрация: 18.04.2009
Сообщений: 435
|
|
| 19.01.2020, 19:15 | |
|
Как я понял нельзя значения типа byte просто так в SQL запрос вставлять.
Надо использовать CONVERT в SQL запросе. Что то типо. -- CONVERT Syntax: CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
1
|
|
|
1524 / 914 / 329
Регистрация: 17.05.2015
Сообщений: 3,438
|
|||
| 19.01.2020, 20:24 | |||
Добавлено через 2 минуты И когда будете вставлять параметр, не забудьте указать у него тип данных - бинарный
0
|
|||
|
Администратор
|
||||||
| 19.01.2020, 20:26 | ||||||
|
McLemore, при ручном конструировании запроса 16-е числа нужно указывать в 16-ом виде. То есть вместо
hxVls[0] нужно написать "0x" + Convert.ToString(hxVls[0], 16).Но лучше и правильнее (гугли SQL injection) использовать параметры
1
|
||||||
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
||
| 20.01.2020, 08:01 [ТС] | ||
(в одной из них в конце вереницы стояло 2F и всё, в остальных одни нули).Люди добрые, может кто-нибудь скинуть рабочий проект? Вот мой проект и бинарники (хотя и разницы нет никакой, что использовать, но всё же)
0
|
||
|
Администратор
|
|
| 20.01.2020, 08:22 | |
|
McLemore, какие типы у колонок b1, b2, b3, b4?
0
|
|
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
|
| 20.01.2020, 08:27 [ТС] | |
|
0
|
|
|
Администратор
|
|
| 20.01.2020, 08:50 | |
|
McLemore, binary(1) я надеюсь?
0
|
|
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
|
| 20.01.2020, 08:58 [ТС] | |
|
0
|
|
|
Администратор
|
|
| 20.01.2020, 09:09 | |
|
McLemore, открою секрет - цифру в скобках можно менять. binary(50) означает что всегда будет храниться 50 байтов. Тебе же нужен только один.
0
|
|
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
||
| 20.01.2020, 09:13 [ТС] | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
|
| 20.01.2020, 09:34 [ТС] | |
|
Изменил на binary(1), картина изменилась, но аномалий меньше не стало. Теперь не пойму что туда вообще подставляется.
По идее значения там должны быть такие: __b1|b2|b3|b4| 1) 94 F3 5F 00 2) 2F F4 B3 01 3) 8A 04 52 02 Проверял, выводя значения массива в консоль, там всё верно, т.е. в массиве не абракадабра Но в таблице почему-то
0
|
|
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
|
| 20.01.2020, 10:01 [ТС] | |
|
Нет, всё таки абракадабра в массиве...
0
|
|
|
Администратор
|
||||||
| 20.01.2020, 12:30 | ||||||
|
McLemore, это потому в цикле чтения байтов используется не та переменная - i, а нужно использовать j.
Еще пара моментов насчет кода чтения байтов 1) Код установки смещения (br.BaseStream.Position) там не нужен. Методы чтения/записи автоматически сдвигают позицию вперед 2) BinaryReader и цикл здесь особо не нужны. Данные можно прочитать короче и быстрее
0
|
||||||
|
0 / 0 / 0
Регистрация: 12.01.2020
Сообщений: 16
|
|
| 20.01.2020, 19:54 [ТС] | |
|
0
|
|
| 20.01.2020, 19:54 | |
|
Помогаю со студенческими работами здесь
15
Что не так в запросе? Что не так в этом запросе? скажите, что не так в запросе?? Что в запросе INSERT INTO не так? Ошибка в запросе что не так сделал Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|