metaclass: (Default)
[personal profile] metaclass
Вот всю жизнь делаешь что-то, думаешь, что это очевидно, а потом берешь другую СУБД и оказывается, что там все сделано по другому.
Вот, например Postgresql vs Firebird:
1) В первом запросы отсылаются на сервер плейнтекстом, даже отпрепаренные с переменными. Во втором - сначала prepare, потом вызов полученного хендла с массивом параметров(бинарным) сколько надо раз. Впрочем, это может быть и особенность либы для доступа к Postgresql.
2) В первом транзакция одна на коннект, во втором - несколько на коннект.
3) В первом единственная ошибка в запросе в транзакции автоматом делает эту транзакцию невалидной целиком, и не дает ничего сделать до rollback. Во втором - транзакцию можно завершить, можно откатить, можно обработать ошибку и продолжить работать дальше. Не выполнится ровно один запрос. Чтобы имитировать такое в postgresql - нужно делать SAVEPOINT перед каждой query и откатываться на нее при ошибке.

Ну еще можно вспомнить про дотнет-драйвера обоих - в первом запрос-внутри-запроса выполнить невозможно, во втором свободно. Т.е. в postgresql "вычитать все шапки накладных, на каждую шапку вычитывая строки" - делается исключительно через жопие, методом "фетчим весь результат первого запроса, закрываем, затем выполняем второй сколько нужно раз".

Date: 2011-12-27 12:10 pm (UTC)
From: [identity profile] metaclass.livejournal.com
А, оно умеет psql в запросах с клиента выполнять?

Date: 2011-12-27 12:13 pm (UTC)
From: [identity profile] plumqqz.livejournal.com
psql - это консольный клиент такой. Не, его не умеет.
А вот plpgsql умеет. В общем должно и всякое остальное уметь, но я не пробовал. Да, и я не знаю, как во всяком основном с транзакциями.

Date: 2011-12-27 12:14 pm (UTC)
From: [identity profile] plumqqz.livejournal.com
Тьфу. s/основном/остальном/;

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 5th, 2025 08:35 am
Powered by Dreamwidth Studios