Russian Qt Forum
Ноябрь 24, 2024, 02:21
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Создание таблицы средствами Qt
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Создание таблицы средствами Qt (Прочитано 13707 раз)
gra
Гость
Создание таблицы средствами Qt
«
:
Июнь 21, 2009, 19:38 »
Приветствую комьюнити !
Есть ли какая-то возможность создать таблицу средствами Qt не прибегая к SQL'ному "create table .... " ?
«
Последнее редактирование: Июнь 21, 2009, 19:49 от gra
»
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 5876
Жаждущий знаний
Re: Создание таблицы средствами Qt
«
Ответ #1 :
Июнь 22, 2009, 06:12 »
А зачем? o_O
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
Barmaglodd
Гость
Re: Создание таблицы средствами Qt
«
Ответ #2 :
Июнь 22, 2009, 07:17 »
Безусловно! Изучаешь формат хранения данных той субд, в которой хочешь создать таблицу, и пишешь нужные структуры руками на диск.
Записан
gra
Гость
Re: Создание таблицы средствами Qt
«
Ответ #3 :
Июнь 22, 2009, 22:15 »
Если честно, я привык работать с полноценными ORM - полностью абстрагируясь от конкретных БД.
Задача стоит в том, чтобы дать пользователю при желании пользоваться не только sqlite но и mysql\pgsql в зависимости от того что у него установлено.
Спасибо за ответы, похоже придется действительно реализовывать все отдельно для каждой.
Записан
break
Гипер активный житель
Offline
Сообщений: 846
Re: Создание таблицы средствами Qt
«
Ответ #4 :
Июнь 23, 2009, 02:09 »
Цитировать
полностью абстрагируясь от конкретных БД
Я могу ошибаться но вроде SQL92 содержит "create table" и абстрагирован от конкретной БД и поддерживается всеми существующими БД. Зачем что-то еще? Если не так поправьте.
Записан
gra
Гость
Re: Создание таблицы средствами Qt
«
Ответ #5 :
Июнь 23, 2009, 03:22 »
Цитата: break от Июнь 23, 2009, 02:09
Зачем что-то еще?
Если честно, я не спец но к примеру, тут -
http://www.sqlite.org/datatype3.html
нет ни слова про тип bool\boolean, хотя в mysql он есть (синоним для tinyint).
Не думаю, что отличия на этом заканчиваются.
Последнее время я пишу на Ruby, в нем есть отличный ORM - ActiveRecord, для того чтоб создать таблицу, нужно написать что-то вроде:
Код:
create_table :users do |t|
t.string :name
t.datetime :created_at
t.boolean :admin
end
Записан
break
Гипер активный житель
Offline
Сообщений: 846
Re: Создание таблицы средствами Qt
«
Ответ #6 :
Июнь 23, 2009, 05:06 »
Цитировать
Если честно, я не спец но к примеру, тут -
http://www.sqlite.org/datatype3.html
нет ни слова про тип bool\boolean, хотя в mysql он есть (синоним для tinyint).
Не понимаю вашей логики почему в доке по sqlite должно быть описание типов MySql???
Цитировать
Последнее время я пишу на Ruby, в нем есть отличный ORM - ActiveRecord
И что будет если я этим механизмом попытаюсь создать поле в БД которая не поддерживает указанный тип?
Записан
gra
Гость
Re: Создание таблицы средствами Qt
«
Ответ #7 :
Июнь 23, 2009, 06:09 »
Цитата: break от Июнь 23, 2009, 05:06
Не понимаю вашей логики почему в доке по sqlite должно быть описание типов MySql???
Перечитайте топик начиная с первого поста.
Цитата: break от Июнь 23, 2009, 05:06
И что будет если я этим механизмом попытаюсь создать поле в БД которая не поддерживает указанный тип?
А как Вы думаете? ActiveRecord поддерживает MySQL, PostgreSQL, SQLite, Oracle, SQLServer и DB2.
Записан
Rcus
Гость
Re: Создание таблицы средствами Qt
«
Ответ #8 :
Июнь 23, 2009, 06:16 »
QtSql достаточно низкоуровневый слой абстракции, а Qt - фреймворк общего назначения, потому не представляет обобщенного синтаксиса для запросов
Записан
gra
Гость
Re: Создание таблицы средствами Qt
«
Ответ #9 :
Июнь 23, 2009, 06:33 »
Цитата: Rcus от Июнь 23, 2009, 06:16
QtSql достаточно низкоуровневый слой абстракции
Да, спасибо, я уже разобрался.
Записан
Admin
Administrator
Джедай : наставник для всех
Offline
Сообщений: 1988
Re: Создание таблицы средствами Qt
«
Ответ #10 :
Июнь 23, 2009, 09:21 »
ORM в QT я думаю еще долго не будет, не тот уровень. Для Ruby и Django ORM хорош, но шаг в сторону - расстрел.
Записан
sikuda
Гость
Re: Создание таблицы средствами Qt
«
Ответ #11 :
Июль 03, 2009, 13:15 »
Так в чем вопрос - напишите сами. Qt как раз средство разработки...
Или про запустите пример SQL Browser (для sqlite) и напишите там CREATE TABLE...
Записан
CroCIV
Гость
Re: Создание таблицы средствами Qt
«
Ответ #12 :
Август 05, 2009, 15:19 »
Цитата: gra от Июнь 23, 2009, 03:22
Если честно, я не спец но к примеру, тут -
http://www.sqlite.org/datatype3.html
нет ни слова про тип bool\boolean, хотя в mysql он есть (синоним для tinyint).
в стандарте SQL92 также есть описание стандартных типов данных. Если какой-то SQL-сервер не поддерживает тип данных, указанных в стандарте прошедшего тысячелетия, то не пользуйтесь этим SQL-сервер, т.к. он не SQL
З.Ы.: Писать независимые от типа сервера SQL конструкции и можно, и нужно и в большинстве случаев оправдано, главное сразу ориентироваться на международный стандарт, а не на внутренний стандарт отдельно взятой компании.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...