понедельник, 21 марта 2016 г.

QSqlRelationalTableModel и setFilter()

При использовании класса QSqlRelationalTableModel для работы с таблицей БД, содержащей внешние ключи, я столкнулся с проблемой установки фильтров посредством функции setFilter(). К сожалению, документация Qt не изобилует объяснениями по работе с данной функцией (что для Qt весьма нетипично), а стоило бы кое-что прояснить...
Особенность заключается в том, что для фильтрации данных по столбцу, для которого вы установили, к примеру
my_relation_table_model->setRelation(3, QSqlRelation("customers", "id", "name"));
фильтр будет выглядеть следующим образом
my_relation_table_model->setFilter("relTblAl_3.name='" + some_text + "'");
Вы поняли? Такая дикая неочевидность, да еще и никак не отраженная в документации, меня весьма удивила.

Спасибо вот этой заметке. Сам бы я долго гадал.

Qt. Деактивация консольного окна в приложении с GUI

Если по каким-либо причинам запуск вашего приложения с GUI на Qt происходит совместно с консольным окном (случается под Windows, например, при использовании функционала из модуля testlib), а оно вам совсем не надо, то не отчаивайтесь, все поправимо ) Для деактивации консольного окна необходимо добавить в файл проекта следующие указания
QMAKE_LFLAGS_CONSOLE = -Wl,-subsystem,windows

sqlite и таблицы с внешними ключами

Если вы столкнулись с тем, что у вас не работают внешние ключи в базе данных sqlite, то я более, чем уверен, что вы забыли о том, что первым запросом к такой БД должен быть
PRAGMA foreign_keys=ON

sqlite. Экспорт и импорт данных на примерах

В данной заметке я хочу привести примеры экспорта и импорта данных при работе с sqlite. Будем использовать утилиту sqlite3.

Пример экспорта таблиц базы в файлы формата csv.
[pa23@pa23comp 1]$ sqlite3 my_database.db
SQLite version 3.11.1 2016-03-03 16:17:53
Enter ".help" for usage hints.
sqlite> .tables
table1  table2
sqlite> .header on
sqlite> .mode csv
sqlite> .once table1.csv
sqlite> select * from table1;
sqlite> .once table2.csv
sqlite> select * from table2;
sqlite> .exit
[pa23@pa23comp 1]$ ls
my_database.db  table1.csv  table2.csv
[pa23@pa23comp 1]$ 
Пример импорта данных из файлов csv в таблицы базы.
[pa23@pa23comp 1]$ ls
my_database.db  table1.csv  table2.csv
[pa23@pa23comp 1]$ sqlite3 my_database.db
SQLite version 3.11.1 2016-03-03 16:17:53
Enter ".help" for usage hints.
sqlite> .tables
table1  table2
sqlite> .mode csv
sqlite> .import table1.csv table1
sqlite> .import table2.csv table2
sqlite> .exit
[pa23@pa23comp 1]$ 
Пример сохранения схемы базы данных в файл sql.
[pa23@pa23comp 1]$ ls
my_database.db
[pa23@pa23comp 1]$ sqlite3 my_database.db .schema > my_database_schema.sql
[pa23@pa23comp 1]$ ls
my_database.db  my_database_schema.sql
[pa23@pa23comp 1]$ cat my_database_schema.sql 
CREATE TABLE table1 (id INTEGER PRIMARY KEY, name TEXT NOT NULL UNIQUE);
CREATE TABLE table2 (id INTEGER PRIMARY KEY, name TEXT NOT NULL UNIQUE);
[pa23@pa23comp 1]$ 
Пример полного бэкапа базы данных в файл sql (схема и данные).
[pa23@pa23comp 1]$ ls
my_database.db  my_database_schema.sql
[pa23@pa23comp 1]$ sqlite3 my_database.db .dump > my_database_dump.sql
[pa23@pa23comp 1]$ ls
my_database.db  my_database_dump.sql  my_database_schema.sql
[pa23@pa23comp 1]$ cat my_database_dump.sql 
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE TABLE table1 (id INTEGER PRIMARY KEY, name TEXT NOT NULL UNIQUE);
INSERT INTO "table1" VALUES(1,'Yaroslavl');
INSERT INTO "table1" VALUES(2,'Vologda');
INSERT INTO "table1" VALUES(3,'Kostroma');
INSERT INTO "table1" VALUES(4,'Ivanovo');
CREATE TABLE table2 (id INTEGER PRIMARY KEY, name TEXT NOT NULL UNIQUE);
INSERT INTO "table2" VALUES(1,'Volga');
INSERT INTO "table2" VALUES(2,'Toshnya');
INSERT INTO "table2" VALUES(3,'Kostroma');
INSERT INTO "table2" VALUES(4,'Uvod');
COMMIT;
[pa23@pa23comp 1]$ 
Пример восстановления базы данных из скрипта sql.
[pa23@pa23comp 1]$ ls
my_database.db  my_database_dump.sql  my_database_schema.sql
[pa23@pa23comp 1]$ sqlite3 my_new_database.db
SQLite version 3.11.1 2016-03-03 16:17:53
Enter ".help" for usage hints.
sqlite> .read my_database_schema.sql 
sqlite> .exit
[pa23@pa23comp 1]$ 

пятница, 11 марта 2016 г.

Emacs Lisp. HEX to DEC and DEC to HEX

Последнее время частенько требуется по-быстрому перевести значения каких-нибудь параметров из hex в dec или наоборот. Наш самый надежный друг и товарищ Emacs всегда под рукой, а его служебный буфер *scratch*, в котором можно выполнять код Emacs Lisp, всегда готов услужить. Калькуляторами я не пользуюсь давно, ибо с помощью Emacs прикинуть какие-то цифры весьма и весьма удобно. И не только прикинуть, а еще и сконвертировать из одной системы счисления в другую. Да, я знаю о встроенном в Emacs калькуляторе, но работать с кодом Emacs Lisp, лично мне, как-то удобнее.
Итак, для того, чтобы преобразовать десятичное число в шестнадцатеричное или наоборот, следует воспользоваться встроенной в Emacs Lisp функцией format. Привожу примеры ее использования.
(format "%d" #x07d0)
"2000"

(format "%x" 505)
"1f9"

(format "%04x" 505)
"01f9"

(upcase (format "%04x" 505))
"01F9"