Russian Qt Forum
Май 06, 2024, 23:15 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: Есть ли где поподробнее про QT и PostgreSQL  (Прочитано 7006 раз)
Anton
Гость
« : Ноябрь 04, 2005, 22:22 »

На уровне простейших приложений или tutoriala?
QT 4.0/4.0.1 Postgre 8.0/8.0.3
Записан
AlexKiriukha
Гость
« Ответ #1 : Ноябрь 06, 2005, 12:49 »

Цитата: "Anton"
На уровне простейших приложений или tutoriala?
QT 4.0/4.0.1 Postgre 8.0/8.0.3

Такого не видел, но сам сейчас разбираюсь с их взаимодействием. В принципе, Qt работает с PostgreSQL как и с любой другой базой, для которой есть драйвер. Для этого они все и затеяли.
Пока нашел 2 тонкости (возможно они есть в документации):
1. Название таблицы в программе на Qt нужно писать в нижнем регистре, хотя в PostgreSQL  написано в разных регистрах.
2. Нужно обязательно создавать PRIMARY KEY. Без него редактировать базу не удастся. Это конечно логично, но не очевидно.
На данный момент не получается затолкнуть данные в BYTEA. Хочу туда маленькие картинки ложить, а не используя BLOB.
Записан
KADABRA
Гость
« Ответ #2 : Ноябрь 06, 2005, 15:42 »

А как с PostgreSQL 8.1 (которая пока-что RC1) дела обстоят?
Записан
AlexKiriukha
Гость
« Ответ #3 : Ноябрь 07, 2005, 10:23 »

Опа. Я боканул. У меня PostgreSQL версии 7.4.8 Грустный
Записан
uckpeHHeBauu
Гость
« Ответ #4 : Ноябрь 07, 2005, 13:01 »

Цитата: "AlexKiriukha"
Цитата: "Anton"
2. Нужно обязательно создавать PRIMARY KEY. Без него редактировать базу не удастся.
только если используешь DataTable иначе все нормально
Записан
AlexKiriukha
Гость
« Ответ #5 : Ноябрь 08, 2005, 10:58 »

Цитата: "uckpeHHeBauu"
только если используешь DataTable иначе все нормально

По другому не пробовал Улыбающийся Но для DataTable - это точно!
Записан
uckpeHHeBauu
Гость
« Ответ #6 : Ноябрь 08, 2005, 11:49 »

лучше используй просто QTable функциональность выше
Записан
Evil_Genius
Гость
« Ответ #7 : Ноябрь 09, 2005, 16:42 »

Народ, всем здрасте. Такая проблема. Есть тестовая БД, в ней одна таблица имеет поля data и time с дефолтными значениями current_data и current_time. Когда вношу данные через QSqlQuery - все ок, они заполняются. Если через QSqlCursor - то эти поля остаются пустыми, значения по умолчанию не ставятся. Почему?
Записан
uckpeHHeBauu
Гость
« Ответ #8 : Ноябрь 09, 2005, 16:46 »

Цитата: "Evil_Genius"
Народ, всем здрасте. Такая проблема. Есть тестовая БД, в ней одна таблица имеет поля data и time с дефолтными значениями current_data и current_time. Когда вношу данные через QSqlQuery - все ок, они заполняются. Если через QSqlCursor - то эти поля остаются пустыми, значения по умолчанию не ставятся. Почему?


покажи код как через cursor заполняешь
Записан
Evil_Genius
Гость
« Ответ #9 : Ноябрь 09, 2005, 18:11 »

Цитата: "uckpeHHeBauu"
покажи код как через cursor заполняешь


Вот это чисто пробную прожку делаю:
Код:

QSqlQuery query;
query.exec("INSERT INTO log(client,info) VALUES(1,'test')"); //нормально

 QSqlCursor cur("log");
 QSqlRecord *buffer = cur.primeInsert();
 buffer->setValue("client",1);
 buffer->setValue("info","test");
 cur.insert(); // поля date и time дефолтными значениями не заполняются
Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.07 секунд. Запросов: 20.