Я рад сообщить, что вышла новая версия моей Rust-библиотеки для объектно-реляционного отображения - Ormlib 1.0.1. В этой версии было проделано много работы по улучшению архитектуры библиотеки.
В предыдущей версии 0.3.3, Ormlib работал только с базой данных SQLite. Это ограничивало сферы применения библиотеки. В версии 1.0.1 была проделана большая работа по рефакторингу кода, чтобы абстрагировать ее от конкретной реализации СУБД.

После рефакторинга я использовал механизм "features", который позволяет подключать Ormlib либо с поддержкой SQLite, либо с поддержкой MySQL.
[dependencies]
ormlib = {version = "1.0.1", features = ["sqlite"]} # or "mysql"
ormlib_derive = "1.0.1"Для реализации этой возможности был создан трейт ORMTrait, который определяет общий интерфейс для работы с ORM.
Этот трейт реализуется отдельно для SQLite и MySQL. Таким образом я получил гибкую архитектуру, которая позволит в будущем добавлять поддержку и других СУБД.
Трейт ORMTrait предоставляет следующие базовые методы для работы с базой данных:
add()- добавляет данные в базу данныхclose()- закрывает соединение с базой данныхfind_one()- ищет одну запись по IDfind_many()- ищет несколько записей по условиюfind_all()- ищет все записиmodify()- изменяет записьremove()- удаляет записьquery()- выполняет произвольный запросquery_update()- выполняет произвольный запрос с обновлением данныхprotect()- экранирует строку от SQL-инъекцийinit()- выполняет инициализацию базы данных
Чтобы перейти на использование новой версии Ormlib, необходимо код:
use ormlib::{ORM, ORMError};заменить на:
use ormlib::sqlite::ORM; // для перехода на mysql заменить на use ormlib::mysql::ORM;
use ormlib::{ORMError, ORMTrait};Код библиотеки доступен на GitHub по ссылке.
Ссылка на первую статью про Ormlib.
