Здравствуйте, гость ( Вход | Регистрация )
tin_gimranoff | Дата 20.10.2010, 10:27 |
А вообще мне надо заюзать под Linux QT и законектиться к базе. Я нашёл тока mysql++ может быть есть ещё что нить для плюсов для работы с базами? А документацию по Qt почитать не получилось? ... на тему "QtSql Module" Спс, как раз вчера пересобрал Qt c поддержкой этого модуля. Просто первое что я нашёл это было MySQL++ и решил поюзать его. tin_gimranoff, это потому, что сохраняешь указатель на локальные данные ошибка тут
text() возвращает QString, созданный на стеке. Ты берёшь адрес начала данных. Затем, по выходу из функции объект убивается, а указатель указывает на невалидные данные - и где-то потом, в обработчике сообщения кто-то пытается получить доступ к этому мусору тут выход такой:сделать QString HostName QString UserName QString UserPass членами класса (new_connect , например) . Можно даже в одну структурку их определить. Так решится проблема потери валидности данных Спс, сегодня попробую, если получится то буду юзаться всё же Mysql++ вместо QtSql |
|
Алексей1153 | Дата 20.10.2010, 10:21 |
tin_gimranoff, это потому, что сохраняешь указатель на локальные данные ошибка тут
text() возвращает QString, созданный на стеке. Ты берёшь адрес начала данных. Затем, по выходу из функции объект убивается, а указатель указывает на невалидные данные - и где-то потом, в обработчике сообщения кто-то пытается получить доступ к этому мусору тут выход такой:сделать QString HostName QString UserName QString UserPass членами класса (new_connect , например) . Можно даже в одну структурку их определить. Так решится проблема потери валидности данных |
|
tin_gimranoff | Дата 20.10.2010, 10:16 |
[quote name='Алексей1153' date='20.10.2010, 7:02' post='41509'] tin_gimranoff, а ты уверен, что косяк именно в этом месте ? А вот сделай так (это исключает наличие ошибки в этом месте):
Так пробовал работает. Но стоит вместо статических значений запихнуть переменные, вылетает, соответственно ошибка именно в этой строке. |
|
BRE | Дата 20.10.2010, 7:10 |
А вообще мне надо заюзать под Linux QT и законектиться к базе. Я нашёл тока mysql++ может быть есть ещё что нить для плюсов для работы с базами? А документацию по Qt почитать не получилось? ... на тему "QtSql Module" |
|
Алексей1153 | Дата 20.10.2010, 6:02 |
tin_gimranoff, а ты уверен, что косяк именно в этом месте ? А вот сделай так (это исключает наличие ошибки в этом месте):
и законектиться к базе. тип базы - ? От способ подключения к базе не зависит от языка программирования |
|
tin_gimranoff | Дата 19.10.2010, 22:37 |
проект вылетает вместе с QtCreator'ом прям с креатором ? Сильно! Пиши разработчикам о глюке ![]() а так если
А так он ругается вообще на несовместимость типов, т.к. connect требует в качестве аргументов const* char, а в QT объекты обрабатывают строки как я понимаю в QString А вообще мне надо заюзать под Linux QT и законектиться к базе. Я нашёл тока mysql++ может быть есть ещё что нить для плюсов для работы с базами? |
|
Алексей1153 | Дата 19.10.2010, 19:18 |
проект вылетает вместе с QtCreator'ом прям с креатором ? Сильно! Пиши разработчикам о глюке ![]() а так если
|
|
tin_gimranoff | Дата 19.10.2010, 17:28 |
Всем доброго времени суток. Помогите плз... пишу вот такой код:
И когда дело доходит до этого события то проект вылетает вместе с QtCreator'ом с ошибкой сегментирования. Причём точно знаю что ошибку вызывает строка if(!test_connect.connect("information_schema", HostName, UserName, UserPass, DataBasePort)) Почему так происходит, объясните плз, и как это дело исправить? Заранее СПС!!!! |
|
Просмотр темы полностью (откроется в новом окне) | |
![]() |
Текстовая версия | Сейчас: 6.12.2023, 1:51 |