MySQL & mSQL



              

Динамическое соединение с базами данных


Тот метод API, который мы до сих пор обсуждали в этой главе, дает, в сущности, все необходимое для простых и наиболее часто встречающихся повседневных задач выборки, вставки, обновления и удаления данных в базе. В некоторых более сложных приложениях может оказаться, что вы ничего (или чего-нибудь) не знаете о базе данных, с которой соединяетесь и которой посылаете команды. Хотя оба API поддерживают метаданные уровня базы данных - информацию времени выполнения о базе данных, с которой соединены, - только MySQL API обеспечивает полную поддержку динамически генерируемых вызовов SQL, включая метаданные результирующего набора.

Описатели команд в MySQL

Как уже отмечалось, в MySQL есть два средства обработки запросов. Более простая форма возвращает результирующий набор в виде списка списков. Более сложная форма возвращает описатель команды.

Описатель команды представляет результаты обработки запроса к MySQL через метод query() (в противоположность использованию метода do()). Пример 11-2 показывает, как можно использовать описатель команды для получения информации времени выполнения о запросе или команде обновления.

Пример 11-2. Динамический доступ к базе данных MySQL с помощью описателя команды

[7:20pm] athens> python

Python 1.5.1 (#1, Jun 13 1998, 22:38:15) [GCC 2.7.2] on- sunos5

Copyright 1991-1995 Stichting Mathematisch Centrum, Amsterdam

>>> import MySQL;

>>> db = MySQL,con.nect();

>>> db.selectdb('db_test-);

>>> result - db.query("INSERT INTO test(test_id,test_val) VALUES(4,

'Bing!')");

>>> print result.affectedrows();

1

>>> result = db.query("SELECT * FROM test");

>>> print result. numrows();

3

>>> print result.fields();

[['test_id', 'test', 'long', 11, 'notnull'], ['test_val', 'test', 'string',

100, "]]

>>> print result, fetchrows(-l);

[[1, 'This is a test.'], [2, 'This is a test.'], [4. 'Bing!']]

>>>

В дополнение к результирующему набору запроса можно с помощью описателя команды получить число строк, затронутых операциями обновления, вставки или удаления. В примере 11-2 мы получили количество строк, возвращенных запросом, и подробные сведения о колонках, представленных в результирующем наборе.




Содержание  Назад  Вперед