Эй, мы хотели получить список в нисходящем порядке:
>>>> curs.execute('SELECT * from zoo ORDER BY count DESC')
>
>>>> curs.fetchall()
>[('duck', 5, 0.0), ('bear', 2, 1000.0), ('weasel', 1, 2000.0)]
Какие животные обходятся нам дороже всего?
>>>> curs.execute('''SELECT * FROM zoo WHERE
>…·····damages = (SELECT MAX(damages) FROM zoo)''')
>
>>>> curs.fetchall()
>[('weasel', 1, 2000.0)]
Вы могли бы подумать, что это медведи. Лучше всегда проверять актуальные данные.
Перед тем как оставить в покое SQLite, нам нужно прибраться. Если мы открывали соединение и курсор, нужно закрыть их после того, как работа будет закончена:
>>>> curs.close()
>>>> conn.close()
MySQL (http://www.mysql.com/) — это очень популярная реляционная база данных с открытым исходным кодом. В отличие от SQLite она является настоящим сервером, поэтому клиенты могут получать к ней доступ с разных устройств всей сети.
MysqlDB (http://sourceforge.net/projects/mysql-python) является самым популярным драйвером для MySQL, но его еще не портировали в Python 3. В табл. 8.3 перечислены драйверы, которые вы можете использовать для того, чтобы получить доступ к MySQL из Python.
Таблица 8.3. Драйверы MySQL
PostgreSQL (http://www.postgresql.org/) — реляционная база данных с открытым исходным кодом, имеющая широкие возможности и гораздо более продвинутая, чем MySQL. В табл. 8.4 показаны драйверы Python, которые вы можете использовать для того, чтобы получить к ней доступ.
Таблица 8.4. Драйверы PostgreSQL
SQL не во всех реляционных базах данных одинаков, и DB-API дает вам ограниченный набор возможностей. Каждая база данных реализует определенный диалект, отражая свои особенности и философию. Многие библиотеки пытаются тем или иным способом компенсировать эти различия. Самая популярная библиотека для работы с разными базами данных — SQLAlchemy (http://www.sqlalchemy.org/).
Эта библиотека не является стандартной, но она широко известна и используется многими людьми. Вы можете установить ее в свою систему с помощью следующей команды: