Создание sql запросов python

Содержание
  1. Как использовать Python для работы с реляционными базами данных
  2. Введение в реляционные базы данных
  3. Подключение к базе данных с использованием Python
  4. SQLite
  5. MySQL
  6. PostgreSQL
  7. Выполнение SQL-запросов с использованием Python
  8. Извлечение данных из базы данных с использованием Python
  9. Python: Работа с базой данных, часть 1/2: Используем DB-API
  10. Готовим инвентарь для дальнейшей комфортной работы
  11. Python DB-API модули в зависимости от базы данных
  12. Соединение с базой, получение курсора
  13. Чтение из базы
  14. Запись в базу
  15. Разбиваем запрос на несколько строк в тройных кавычках
  16. Объединяем запросы к базе данных в один вызов метода
  17. Делаем подстановку значения в запрос
  18. Делаем множественную вставку строк проходя по коллекции с помощью метода курсора .executemany()
  19. Получаем результаты по одному, используя метод курсора .fetchone()
  20. Курсор как итератор
  21. UPD: Повышаем устойчивость кода
  22. UPD: Использование with в psycopg2
  23. UPD: Ипользование row_factory
  24. Дополнительные материалы (на английском)
  25. Приглашаю к обсуждению:

Как использовать Python для работы с реляционными базами данных

Освойте работу с реляционными базами данных (SQLite, MySQL, PostgreSQL) в Python, используя практические примеры и подключение к базам.

Работа с реляционными базами данных является важным навыком для любого разработчика Python. В этой статье мы рассмотрим, как использовать Python для работы с популярными реляционными базами данных, такими как SQLite, MySQL и PostgreSQL.

Введение в реляционные базы данных

Реляционные базы данных используют таблицы для хранения и организации данных. Таблицы состоят из строк и столбцов, которые представляют собой записи и атрибуты данных соответственно. Реляционные базы данных используют язык SQL (Structured Query Language) для выполнения операций с данными, таких как создание, изменение, удаление и извлечение данных.

Подключение к базе данных с использованием Python

Для работы с реляционными базами данных в Python мы будем использовать библиотеку sqlite3 для SQLite, mysql-connector-python для MySQL и psycopg2 для PostgreSQL. Убедитесь, что вы установили соответствующие библиотеки перед началом работы.

Читайте также:  Python pyusb no backend available

SQLite

SQLite — это легковесная база данных, которая хранит данные в файлах на диске. Это отличное решение для небольших проектов, не требующих высокой производительности и масштабируемости.

Пример подключения к базе данных SQLite:

import sqlite3 conn = sqlite3.connect('my_database.db')

MySQL

Для подключения к базе данных MySQL вам понадобится установить библиотеку mysql-connector-python .

Пример подключения к базе данных MySQL:

import mysql.connector conn = mysql.connector.connect( host="your_host", user="your_username", password="your_password", database="your_database" )

PostgreSQL

Для подключения к базе данных PostgreSQL вам понадобится установить библиотеку psycopg2 .

Пример подключения к базе данных PostgreSQL:

import psycopg2 conn = psycopg2.connect( host="your_host", user="your_username", password="your_password", database="your_database" )

Выполнение SQL-запросов с использованием Python

После подключения к базе данных вы можете выполнять SQL-запросы с помощью Python. Для этого используйте метод execute() курсора, который предоставляет интерфейс для взаимодействия с базой данных.

Пример создания таблицы и добавления записи:

cursor = conn.cursor() # Создание таблицы cursor.execute(""" CREATE TABLE IF NOT EXISTS users ( id INTEGER PRIMARY KEY, name TEXT NOT NULL, age INTEGER ) """) # Добавление записи cursor.execute(""" INSERT INTO users (name, age) VALUES ('John Doe', 30) """) # Сохранение изменений conn.commit() # Закрытие курсора и соединения cursor.close() conn.close()

Извлечение данных из базы данных с использованием Python

Для извлечения данных из базы данных используйте метод fetchall() или fetchone() курсора после выполнения SQL-запроса.

Пример извлечения всех записей из таблицы:

cursor = conn.cursor() # Выполнение SELECT-запроса cursor.execute("SELECT * FROM users") # Извлечение всех записей rows = cursor.fetchall() # Вывод результатов for row in rows: print(row) cursor.close() conn.close()

Теперь вы знаете основы работы с реляционными базами данных с использованием Python. Удачи вам в изучении и применении этого навыка на практике! 😃

Источник

Python: Работа с базой данных, часть 1/2: Используем DB-API

Python DB-API – это не конкретная библиотека, а набор правил, которым подчиняются отдельные модули, реализующие работу с конкретными базами данных. Отдельные нюансы реализации для разных баз могут отличаться, но общие принципы позволяют использовать один и тот же подход при работе с разными базами данных.

В статье рассмотрены основные методы DB-API, позволяющие полноценно работать с базой данных. Полный список можете найти по ссылкам в конец статьи.

Требуемый уровень подготовки: базовое понимание синтаксиса SQL и Python.

Готовим инвентарь для дальнейшей комфортной работы

    Python имеет встроенную поддержку SQLite базы данных, для этого вам не надо ничего дополнительно устанавливать, достаточно в скрипте указать импорт стандартной библиотеки

Примечание: внося изменения в базу не забудьте их применить, так как база с непримененными изменениями остается залоченной.

Вы можете использовать (последние два варианта кросс-платформенные и бесплатные):

Python DB-API модули в зависимости от базы данных

Соединение с базой, получение курсора

Для начала рассмотрим самый базовый шаблон DB-API, который будем использовать во всех дальнейших примерах:

# Импортируем библиотеку, соответствующую типу нашей базы данных import sqlite3 # Создаем соединение с нашей базой данных # В нашем примере у нас это просто файл базы conn = sqlite3.connect('Chinook_Sqlite.sqlite') # Создаем курсор - это специальный объект который делает запросы и получает их результаты cursor = conn.cursor() # ТУТ БУДЕТ НАШ КОД РАБОТЫ С БАЗОЙ ДАННЫХ # КОД ДАЛЬНЕЙШИХ ПРИМЕРОВ ВСТАВЛЯТЬ В ЭТО МЕСТО # Не забываем закрыть соединение с базой данных conn.close()

При работе с другими базами данных, используются дополнительные параметры соединения, например для PostrgeSQL:

conn = psycopg2.connect( host=hostname, user=username, password=password, dbname=database)

Чтение из базы

# Делаем SELECT запрос к базе данных, используя обычный SQL-синтаксис cursor.execute("SELECT Name FROM Artist ORDER BY Name LIMIT 3") # Получаем результат сделанного запроса results = cursor.fetchall() results2 = cursor.fetchall() print(results) # [('A Cor Do Som',), ('Aaron Copland & London Symphony Orchestra',), ('Aaron Goldberg',)] print(results2) # []

Обратите внимание: После получения результата из курсора, второй раз без повторения самого запроса его получить нельзя — вернется пустой результат!

Запись в базу

# Делаем INSERT запрос к базе данных, используя обычный SQL-синтаксис cursor.execute("insert into Artist values (Null, 'A Aagrh!') ") # Если мы не просто читаем, но и вносим изменения в базу данных - необходимо сохранить транзакцию conn.commit() # Проверяем результат cursor.execute("SELECT Name FROM Artist ORDER BY Name LIMIT 3") results = cursor.fetchall() print(results) # [('A Aagrh!',), ('A Cor Do Som',), ('Aaron Copland & London Symphony Orchestra',)]

Примечание: Если к базе установлено несколько соединений и одно из них осуществляет модификацю базы, то база SQLite залочивается до завершения (метод соединения .commit()) или отмены (метод соединения .rollback()) транзакции.

Разбиваем запрос на несколько строк в тройных кавычках

Длинные запросы можно разбивать на несколько строк в произвольном порядке, если они заключены в тройные кавычки — одинарные (»’…»’) или двойные («»». «»»)

cursor.execute(""" SELECT name FROM Artist ORDER BY Name LIMIT 3 """)

Конечно в таком простом примере разбивка не имеет смысла, но на сложных длинных запросах она может кардинально повышать читаемость кода.

Объединяем запросы к базе данных в один вызов метода

Метод курсора .execute() позволяет делать только один запрос за раз, при попытке сделать несколько через точку с запятой будет ошибка.

cursor.execute(""" insert into Artist values (Null, 'A Aagrh!'); insert into Artist values (Null, 'A Aagrh-2!'); """) # sqlite3.Warning: You can only execute one statement at a time. 

Для решения такой задачи можно либо несколько раз вызывать метод курсора .execute()

cursor.execute("""insert into Artist values (Null, 'A Aagrh!');""") cursor.execute("""insert into Artist values (Null, 'A Aagrh-2!');""")

Либо использовать метод курсора .executescript()

cursor.executescript(""" insert into Artist values (Null, 'A Aagrh!'); insert into Artist values (Null, 'A Aagrh-2!'); """)

Данный метод также удобен, когда у нас запросы сохранены в отдельной переменной или даже в файле и нам его надо применить такой запрос к базе.

Делаем подстановку значения в запрос

Важно! Никогда, ни при каких условиях, не используйте конкатенацию строк (+) или интерполяцию параметра в строке (%) для передачи переменных в SQL запрос. Такое формирование запроса, при возможности попадания в него пользовательских данных – это ворота для SQL-инъекций!

Правильный способ – использование второго аргумента метода .execute()

# C подставновкой по порядку на места знаков вопросов: cursor.execute("SELECT Name FROM Artist ORDER BY Name LIMIT ?", ('2')) # И с использованием именнованных замен: cursor.execute("SELECT Name from Artist ORDER BY Name LIMIT :limit", )

Примечание 1: В PostgreSQL (UPD: и в MySQL) вместо знака ‘?’ для подстановки используется: %s

Примечание 2: Таким способом не получится заменять имена таблиц, одно из возможных решений в таком случае рассматривается тут: stackoverflow.com/questions/3247183/variable-table-name-in-sqlite/3247553#3247553

UPD: Примечание 3: Благодарю Igelko за упоминание параметра paramstyle — он определяет какой именно стиль используется для подстановки переменных в данном модуле.
Вот ссылка с полезным приемом для работы с разными стилями подстановок.

Делаем множественную вставку строк проходя по коллекции с помощью метода курсора .executemany()

# Обратите внимание, даже передавая одно значение - его нужно передавать кортежем! # Именно по этому тут используется запятая в скобках! new_artists = [ ('A Aagrh!',), ('A Aagrh!-2',), ('A Aagrh!-3',), ] cursor.executemany("insert into Artist values (Null, ?);", new_artists)

Получаем результаты по одному, используя метод курсора .fetchone()

Он всегда возвращает кортеж или None. если запрос пустой.

cursor.execute("SELECT Name FROM Artist ORDER BY Name LIMIT 3") print(cursor.fetchone()) # ('A Cor Do Som',) print(cursor.fetchone()) # ('Aaron Copland & London Symphony Orchestra',) print(cursor.fetchone()) # ('Aaron Goldberg',) print(cursor.fetchone()) # None

Важно! Стандартный курсор забирает все данные с сервера сразу, не зависимо от того, используем мы .fetchall() или .fetchone()

Курсор как итератор

# Использование курсора как итератора for row in cursor.execute('SELECT Name from Artist ORDER BY Name LIMIT 3'): print(row) # ('A Cor Do Som',) # ('Aaron Copland & London Symphony Orchestra',) # ('Aaron Goldberg',)

UPD: Повышаем устойчивость кода

Благодарю paratagas за ценное дополнение:
Для большей устойчивости программы (особенно при операциях записи) можно оборачивать инструкции обращения к БД в блоки «try-except-else» и использовать встроенный в sqlite3 «родной» объект ошибок, например, так:

try: cursor.execute(sql_statement) result = cursor.fetchall() except sqlite3.DatabaseError as err: print("Error: ", err) else: conn.commit()

UPD: Использование with в psycopg2

 with psycopg2.connect("dbname='habr'") as conn: with conn.cursor() as cur:

Некоторые объекты в Python имеют __enter__ и __exit__ методы, что позволяет «чисто» взаимодействовать с ними, как в примере выше.

UPD: Ипользование row_factory

Благодарю remzalp за ценное дополнение:
Использование row_factory позволяет брать метаданные из запроса и обращаться в итоге к результату, например по имени столбца.
По сути — callback для обработки данных при возврате строки. Да еще и полезнейший cursor.description, где есть всё необходимое.

import sqlite3 def dict_factory(cursor, row): d = <> for idx, col in enumerate(cursor.description): d[col[0]] = row[idx] return d con = sqlite3.connect(":memory:") con.row_factory = dict_factory cur = con.cursor() cur.execute("select 1 as a") print(cur.fetchone()["a"])

Дополнительные материалы (на английском)

    Краткий бесплатный он-лайн курс — Udacity — Intro to Relational Databases — Рассматриваются синтаксис и принципы работы SQL, Python DB-API – и теория и практика в одном флаконе. Очень рекомендую для начинающих!

Приглашаю к обсуждению:

  • Если я где-то допустил неточность или не учёл что-то важное — пишите в комментариях, важные комментарии будут позже добавлены в статью с указанием вашего авторства.
  • Если какие-то моменты не понятны и требуется уточнение — пишите ваши вопросы в комментариях — или я или другие читатели дадут ответ, а дельные вопросы с ответами будут позже добавлены в статью.

Источник

Оцените статью