DAtabase

Quick overview of SQLite

SQLite — это библиотека, написанная на языке C, которая обеспечивает работу с SQL. В основу БД легли принципы ACID.

Работая с SQLite следует понимать понятие транзакции. Транзакция — это операция по изменению записи в базе.

ACID описывает требования к к СУБД, обеспечивающие наиболее надёжную и предсказуемую её работу.

  • Atomicity — Атомарность
Атомарность гарантирует, что никакая транзакция не будет зафиксирована в системе частично. Будут либо выполнены все её подоперации, либо не выполнено ни одной. Поскольку на практике невозможно одновременно и атомарно выполнить всю последовательность операций внутри транзакции, вводится понятие «отката» (rollback): если транзакцию не удаётся полностью завершить, результаты всех её до сих пор произведённых действий будут отменены и система вернётся во «внешне исходное» состояние — со стороны будет казаться, что транзакции и не было.

  • Consistency — Согласованность
Например, в банковской системе может существовать требование равенства суммы, списываемой с одного счёта, сумме, зачисляемой на другой. Eсли какая-либо транзакция произведёт списание, но не произведёт зачисление, то система останется в некорректном состоянии и свойство согласованности будет нарушено.

  • Isolation — Изолированность
Во время выполнения транзакции параллельные транзакции не должны оказывать влияние на её результат. Изолированность — требование дорогое, поэтому в БД существуют режимы, не полностью изолирующие транзакцию.

  • Durability — Устойчивость
Изменения, сделанные успешно завершённой транзакцией, должны остаться сохранёнными после возвращения системы в работу. Другими словами, если пользователь получил подтверждение от системы, что транзакция выполнена, он может быть уверен, что сделанные им изменения не будут отменены из-за какого-либо сбоя.

Стандартные операции по работе с SQLite:

  1. Select
  2. Create
  3. Insert
  4. Update
  5. Drop
  6. Delete
Плюсы SQLite:

  1. Поддерживает почти все типы операционных систем
  2. Малый вес БД (меньше 400кб)
  3. Написана без использования дополнительных библиотек
  4. Не нужно настраивать
  5. Данные лежат на диске
Типы данных, которые поддерживаются базой:

  1. Null
  2. Integer
  3. Real
  4. Text (UTF-8, UTF-16BE)
  5. BLOB (binary Large Object)
Да, в SQLite нет отдельного Boolean, значения хранятся как integer 0(false) и 1(true)


Daria Korneichuk
iOS Developer
Made on
Tilda