Простой Python. Современный стиль программирования (Любанович) - страница 135

Эй, мы хотели получить список в нисходящем порядке:

>>>> 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

MySQL (http://www.mysql.com/) — это очень популярная реляционная база данных с открытым исходным кодом. В отличие от SQLite она является настоящим сервером, поэтому клиенты могут получать к ней доступ с разных устройств всей сети.

MysqlDB (http://sourceforge.net/projects/mysql-python) является самым популярным драйвером для MySQL, но его еще не портировали в Python 3. В табл. 8.3 перечислены драйверы, которые вы можете использовать для того, чтобы получить доступ к MySQL из Python.


Таблица 8.3. Драйверы MySQL
НазваниеСсылкаПакет PyPiИмпортировать какПримечание
MySQL Connectorhttp://bit.ly/mysql-cpdgmysql-connector-pythonmysql.connector
PYMySQLhttps://github.com/petehunt/PyMySQL/pymysqlpymysql
oursqlhttp://pythonhosted.org/oursql/oursqloursqlТребует наличия клиентской библиотеки MySQL C

PostgreSQL

PostgreSQL (http://www.postgresql.org/) — реляционная база данных с открытым исходным кодом, имеющая широкие возможности и гораздо более продвинутая, чем MySQL. В табл. 8.4 показаны драйверы Python, которые вы можете использовать для того, чтобы получить к ней доступ.


Таблица 8.4. Драйверы PostgreSQL
НазваниеСсылкаПакет PyPiИмпортировать какПримечание
psycopg2http://initd.org/psycopg/psycopg2psycopg2Необходим pg_config из клиентских инструментов PostgreSQL
py-postgresqlhttp://python.projects.pgfoundry.org/py-postgresqlpostgresql

SQLAlchemy

SQL не во всех реляционных базах данных одинаков, и DB-API дает вам ограниченный набор возможностей. Каждая база данных реализует определенный диалект, отражая свои особенности и философию. Многие библиотеки пытаются тем или иным способом компенсировать эти различия. Самая популярная библиотека для работы с разными базами данных — SQLAlchemy (http://www.sqlalchemy.org/).

Эта библиотека не является стандартной, но она широко известна и используется многими людьми. Вы можете установить ее в свою систему с помощью следующей команды: