Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
2 / 2 / 3
Регистрация: 18.10.2014
Сообщений: 98
Записей в блоге: 1
MySQL

Записать данные из полей в Label

07.07.2015, 16:43. Показов 1740. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, у меня такая загвоздка.

Есть 2 формы

1ая- вход используя логин и пароль которые содержаться в бд (mysql)
2ая - при успешном входе открывается и выводится имя, фамилия, e-mail пользователя

данные для mysql

сервер : localhost
логин: root
пароля нету
База данных: registration
Таблица: user

Первая форма сделана, вход работает

C++
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
//---------------------------------------------------------------------------
 
#include <vcl.h>
#include <mysql.h>
#pragma hdrstop
 
#include "Unit1.h"
#include "Unit2.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
 
TForm1 *Form1;
MYSQL *Con;
MYSQL_RES *Res;
MYSQL_FIELD *Fields;
 
MYSQL_ROW row;
unsigned int num_fields;
unsigned int i;
 
void connectsql()
{
    Con=mysql_init(Con);
    Con=mysql_real_connect(Con,"localhost","root","","registration",0,NULL,0);
    if(!Con)
    {
        ShowMessage("Can not connect.");
        Form1->Label5->Caption="error";
        Form1->Label5->Font->Color=clRed;
    }
    else
    {
        Form1->Label5->Caption="enable";
        Form1->Label5->Font->Color=clGreen;
    }
}
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
    connectsql();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Label5Click(TObject *Sender)
{
if(Label5->Caption == "false")
    connectsql();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Label3Click(TObject *Sender)
{
AnsiString login = Edit1->Text;
AnsiString password = Edit2->Text;
AnsiString result;
 
AnsiString query=("SELECT * FROM registration.user WHERE login = '"+Edit1->Text+"' AND password = '"+Edit2->Text+"'");
 
int f=mysql_errno(Con);
 
 
if(f==0)
{
    if (mysql_real_query(Con,query.c_str(),query.Length()))
{
    Form2->Show();
 
}
else // запрос не выполнен
{
    ShowMessage("Такого пользователя не существует");
}
    }
 
    else
    {
        ShowMessage("Error #: " + IntToStr(f) + char(13) + "Message: " + mysql_error(Con));
    }
}
//---------------------------------------------------------------------------
вторая форма , мне непонятно как вывести данные столбцов из таблицы, при этом вход выполнен.

код компилируется , но при нажатии кнопки ничего не выводит..

C++
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
//---------------------------------------------------------------------------
 
#include <vcl.h>
#include <mysql.h>
#pragma hdrstop
 
#include "Unit1.h"
#include "Unit2.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm2 *Form2;
 
MYSQL *Con;
MYSQL_RES *Res;
MYSQL_FIELD *Fields;
 
MYSQL_ROW row;
unsigned int num_fields;
unsigned int i;
 
//---------------------------------------------------------------------------
__fastcall TForm2::TForm2(TComponent* Owner)
    : TForm(Owner)
{
}
//---------------------------------------------------------------------------
void __fastcall TForm2::Button1Click(TObject *Sender)
{
 
    Con=mysql_init(Con);
    Con=mysql_real_connect(Con,"localhost","root","","registration",0,NULL,0);
 
    Res = mysql_store_result(Con);
    if (Res)
    {
        int num_fields = mysql_num_fields(Res);
        mysql_free_result(Res);
        AnsiString query=("SELECT * FROM registration.user WHERE login = '"+Form1->Edit1->Text+"'");
        mysql_real_query(Con,query.c_str(),query.Length());
        num_fields = mysql_num_fields(Res);
        while ((row = mysql_fetch_row(Res)))
        {
            unsigned long *lengths;
            lengths = mysql_fetch_lengths(Res);
            Form2->Label1->Caption=row[3];
            Form2->Label2->Caption=row[4];
            Form2->Label3->Caption=row[6];
 
        }
    }
}
//---------------------------------------------------------------------------

читал информацию на этом сайте, но понял только 1/2 из того что там написано.
с подключением разобрался а вот как вывести информацию не понимаю.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.07.2015, 16:43
Ответы с готовыми решениями:

По нажатию на строку в DBGrid нужно записать в Label значение одного из полей (Id)
Всем привет! У меня такой вопрос есть несколько связанных таблиц , вывожу их в DBGrid и по нажатию на строку в DBGrid нужно записать в...

Ошибка при попытки записать данные в Label из ComboBoxe
Доброго времени суток! Суть программки. В комбобокс попадают все данные пользователей, котоыре есть в БД, после выбора конкретного...

Записать в Label на второй форме контент Label, находящейся на первой
На форме один скажем, находится Лабел1, как сделать так, что находится (название) в этом Лабел ,отображалось на другой форме в другой...

8
Native x86
Эксперт Hardware
 Аватар для quwy
6857 / 3790 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
07.07.2015, 16:54
Nyiann, вы раньше на PHP не программировали, случайно? В delphi/builder принят немного другой подход к взаимодействию с базами данных. Изучайте компоненты на вкладках Data Access и Data Controls, с ними ваша задача решается одной строчкой кода в Button1Click().
0
2 / 2 / 3
Регистрация: 18.10.2014
Сообщений: 98
Записей в блоге: 1
07.07.2015, 17:25  [ТС]
Цитата Сообщение от quwy Посмотреть сообщение
Nyiann, вы раньше на PHP не программировали, случайно? В delphi/builder принят немного другой подход к взаимодействию с базами данных. Изучайте компоненты на вкладках Data Access и Data Controls, с ними ваша задача решается одной строчкой кода в Button1Click().
программировал, я как раз ссылался на пример php.

Я знаю что можно сделать через ADOConnection , я уже много таких программ делал, но там было дело все с MC Access , а тут с SQL базой которая должна располагаться на удаленном сервере.

Я поискал в интернете что то на счет sql и нашел такой ответ который у меня сейчас написан.
Но поискав параллельно другой вариант я наткнулся на SQLConnection , но там при подключении (когда я ввожу все данные) выводит ошибку что не подключиться к серверу и тд тп..

поэтому я остановился на таком варианте как подключить самому mysql добавив его в проект. При этом все работает

если есть возможность помочь с другим подключением к серверу mysql , можете написать как.

пользуюсь BuilderC++ XE8
0
Native x86
Эксперт Hardware
 Аватар для quwy
6857 / 3790 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
07.07.2015, 18:33
Цитата Сообщение от Nyiann Посмотреть сообщение
тут с SQL базой которая должна располагаться на удаленном сервере.
Это что-то меняет?

Цитата Сообщение от Nyiann Посмотреть сообщение
Я поискал в интернете что то на счет sql и нашел такой ответ который у меня сейчас написан.
Можно, конечно и так, но зачем? Если для интерфейса своей программы вы используете библиотеку компонентов VCL, а не чистый WinAPI, то логично ее же использовать и для доступа к данным.

Традиционным для VCL-программ способом установить соединение с удаленным MySQL можно используя ADOConnection, как написано тут, или при помощи сторонних компонентов, например MyDAC.
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
07.07.2015, 20:13
Цитата Сообщение от quwy Посмотреть сообщение
Nyiann, вы раньше на PHP не программировали, случайно? В delphi/builder принят немного другой подход к взаимодействию с базами данных.
Че? У него обычный сишный код, может человеку харит ставить на каждую машину провайдер.
Хотя такой подход обычно годится для чистых Inset-ов в БД а не Select-ов и редактирования.

Добавлено через 3 минуты
Цитата Сообщение от Nyiann Посмотреть сообщение
, но при нажатии кнопки ничего не выводит..
По тому что стоит обрабатывать/выводить ошибки после операций.

Работа с mysql


C++ Builder + MySQL подключение с Денвера
ADO,MySQL
0
Native x86
Эксперт Hardware
 Аватар для quwy
6857 / 3790 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
07.07.2015, 20:45
Цитата Сообщение от Avazart Посмотреть сообщение
Че? У него обычный сишный код, может человеку харит ставить на каждую машину провайдер.
Может я отстал от жизни, но разве mysql.h и та dll, оберткой над которой он является, уже стали стандартными компонентами builder и windows соответственно?

Без сторонних компонентов или библиотек все равно никак не обойдешься.
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
07.07.2015, 20:56
Цитата Сообщение от quwy Посмотреть сообщение
Может я отстал от жизни, но разве mysql.h и та dll, оберткой над которой он является, уже стали стандартными компонентами builder и windows соответственно?
Ну вообще-то без них работать не будет никак.
Компоненты лишь обвертка над этой длл-кой.
Очевидно что таскать одну длл-ку вместе с экзешником может быть удобнее чем ставить на каждую машину провайдер.
0
Native x86
Эксперт Hardware
 Аватар для quwy
6857 / 3790 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
08.07.2015, 11:38
Цитата Сообщение от Avazart Посмотреть сообщение
Компоненты лишь обвертка над этой длл-кой.
Не все. Протокол открыт, и некоторые компоненты (MyDAC, например) реализуют его своими силами.

Цитата Сообщение от Avazart Посмотреть сообщение
Очевидно что таскать одну длл-ку вместе с экзешником может быть удобнее чем ставить на каждую машину провайдер.
Да, но люди зачем-то пишут свой софт на жирных шарпе и жабе, хотя могли бы и на легих сях или асме писать. Тут вопрос элементарного удобтсва.
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
08.07.2015, 13:05
Цитата Сообщение от quwy Посмотреть сообщение
Не все. Протокол открыт, и некоторые компоненты (MyDAC, например) реализуют его своими силами.
Хз вполне возможно, не интересовался, хотя зачем если можно просто прилинковать библиотеку(в том числе статическую) ?

Цитата Сообщение от quwy Посмотреть сообщение
Да, но люди зачем-то пишут свой софт на жирных шарпе и жабе, хотя могли бы и на легих сях или асме писать. Тут вопрос элементарного удобтсва.
Пишут на чем угодно, вопрос в том насколько оно хорошо работает.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.07.2015, 13:05
Помогаю со студенческими работами здесь

Скругление полей у Label
Здравствуйте - возможно ли скругление краёв у label? Я их скруглил, но проблема вот в чём - она должна быть не видима до нажатия по...

Перебор полей класса в цикле и вывод в Label
Есть класс с многими полями, хочу их вывести как это сделать через перебор? class Myclass{ public int a; public int ccc; ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера 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