Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 27.03.2018
Сообщений: 107

Значение типа "DataRow" невозможно преобразовать в STRING

12.03.2019, 16:52. Показов 2302. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
При выполнении кода в цикле DO While выскакивает ошибка (см. заголовок)
Подскажите пожалуйста в чем моя ошибка?
Задача - заполнить 3 RichTextBox данными из запроса в БД
VB.NET
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
32
33
34
Public Class Form2
    Private Sub Form2_Load(sender As Object, e As EventArgs) Handles MyBase.Load
 
        lblTestName.Text = Form1.cmbTest.Text
        lblName.Text = Form1.TextBox1.Text
 
        Dim sqlstr As String = ("select * from queans where ""NUMBER""=1")
        Debug.Print(sqlstr)
        Dim conString As String
        Dim sqlcmd As New Npgsql.NpgsqlCommand(sqlstr, con)
        Dim DA As Npgsql.NpgsqlDataAdapter
        Dim DT As New Data.DataTable
        Dim DR As Npgsql.NpgsqlDataReader
 
 
        conString = "SERVER=192.168.92.202;PORT=5432; USER ID=*****; PASSWORD=******!; DATABASE=divisions"
        con = New Npgsql.NpgsqlConnection(conString)
 
        con.Open()
 
        DA = New Npgsql.NpgsqlDataAdapter(sqlcmd)
        DA.Fill(DT)
        DR = sqlcmd.ExecuteReader
        Do While DR.Read
            rtbQue.Text = DT.Rows(1)
            rtbAns1.Text = DT.Rows(2)
            rtbAns2.Text = DT.Rows(3)
        Loop
 
        'rtbQue.Text = sqlcmd.ExecuteScalar()
 
 
    End Sub
End Class
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.03.2019, 16:52
Ответы с готовыми решениями:

Невозможно преобразовать значение типа "1-мерный массив из String" в "String"
Как такое побороть? Уже что только не пробовал.

Невозможно преобразовать значение типа "string" в "System.Windows.Forms.Label"
Невозможно преобразовать значение типа "string" в "System.Windows.Forms.Label". Вот программа: в VB 6.0 работает нормально, а в VB...

Невозможно преобразовать значение типа "String" в "System.Windows.Forms.TextBox"
я уже третий раз пытаюсь задать вопрос, но не могу найти потом его((((((( я не программист, и программой мне нужно воспользоваться...

6
1548 / 1521 / 325
Регистрация: 03.10.2012
Сообщений: 1,551
12.03.2019, 17:36
VB.NET
1
rtbQue.Text = DT.Rows(1).Item("имя поля")   '(или индекс)
Добавлено через 2 минуты
VB.NET
1
rtbQue.Text = DT.Rows(1)(0)
0
0 / 0 / 0
Регистрация: 27.03.2018
Сообщений: 107
12.03.2019, 17:55  [ТС]
Спасибо - исправил. Но теперь почему-то в 23 строке вываливается исключение
Вызвано исключение: "System.InvalidOperationException" в mscorlib.dll
0
1728 / 1595 / 166
Регистрация: 25.07.2015
Сообщений: 2,674
12.03.2019, 18:37
Цитата Сообщение от Yur1S Посмотреть сообщение
Но теперь почему-то в 23 строке вываливается исключение
Потому что надо наверное объявить экземпляр рейдера
VB.NET
1
Dim DR As New Npgsql.NpgsqlDataReader
VB.NET
1
DR = sqlcmd.ExecuteReader
.
0
0 / 0 / 0
Регистрация: 27.03.2018
Сообщений: 107
13.03.2019, 10:54  [ТС]
Цитата Сообщение от Kulma Посмотреть сообщение
Потому что надо наверное объявить экземпляр рейдера
VB.NET
1
Dim DR As New Npgsql.NpgsqlDataReader
VB.NET
1
DR = sqlcmd.ExecuteReader
.
Так ведь DR в этом блоке уже объявлена?
И студия в этом случае пишет что:
Ошибка BC30569 "New" не может использоваться для класса, объявленного как "MustInherit".
0
1548 / 1521 / 325
Регистрация: 03.10.2012
Сообщений: 1,551
13.03.2019, 11:59
Лучший ответ Сообщение было отмечено Yur1S как решение

Решение

Цитата Сообщение от Yur1S Посмотреть сообщение
Так ведь DR в этом блоке уже объявлена?
Не понимаю, зачем вообще здесь нужен ридер, ведь данные у вас уже залиты в таблицу адаптером. Берите их прямо из таблицы.
2
0 / 0 / 0
Регистрация: 27.03.2018
Сообщений: 107
13.03.2019, 12:26  [ТС]
MrCrown, Правильно!!!! Убрал нафиг датаридер (как сам не сообразил? Зашорился)
все теперь выглядит вот так и работает!!!
VB.NET
1
2
3
4
5
6
7
8
9
10
Dim sqlcmd As New Npgsql.NpgsqlCommand(sqlstr, con)
        Dim DA As Npgsql.NpgsqlDataAdapter
        DA = New Npgsql.NpgsqlDataAdapter(sqlcmd)
        DA.Fill(DT)
        'DR = sqlcmd.ExecuteReader
        'Do While DR.Read
        rtbQue.Text = DT.Rows(0)(0)
        rtbAns1.Text = DT.Rows(0)(1)
        rtbAns2.Text = DT.Rows(0)(2)
        rtbAns3.Text = DT.Rows(0)(3)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.03.2019, 12:26
Помогаю со студенческими работами здесь

Как преобразовать System.Data.DataRow в String?
есть такая конструкция: $bases=Invoke-Sqlcmd -Query "SELECT name FROM master.sys.databases where not (name='main' or name='master' or...

Оператор & невозможно применить к операнду типа string и string
Хельп 4 и 24 строка public static void zad1(int b, int b1, int max, byte n, byte m, TextBox ot, int x) { ...

Невозможно преобразовать значение типа "double"
Ошибка 1 Невозможно преобразовать значение типа "Double" в "System.Windows.Forms.TextBox". C:\Users\Игорь\AppData\Local\Temporary...

Неявное преобразование типа string в string[] невозможно
На строчке mas = textBox1.Text выдает ошибку "Неявное преобразование типа string в string невозможно Очень нужно, помогите Задание:...

Невозможно преобразовать 'System::String ^' в 'int'
VS 2008 C++ private: System::Void textBox4_TextChanged(System::Object^ sender, System::EventArgs^ e) { a = textBox4->Text; ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru