pub enum DatabaseType {
Postgres,
MySQL,
SQLite,
MongoDB,
Redis,
}Expand description
Enumeration of supported database engine types.
This enum represents the different database backends that DMSC can connect to. Each database type has specific connection requirements and may use different underlying drivers or client libraries.
§Currently Implemented
| Database Type | Feature Flag | Status |
|---|---|---|
| PostgreSQL | postgres | ✅ Available |
| MySQL | mysql | ✅ Available |
| SQLite | sqlite | ✅ Available |
| MongoDB | mongodb | 🔜 Planned |
| Redis | redis | 🔜 Planned |
§Roadmap
MongoDB and Redis support are planned for future releases. The enum variants are reserved to maintain API stability when these features are added.
§Usage
use dmsc::database::DatabaseType;
fn get_preferred_db() -> DatabaseType {
DatabaseType::Postgres
}Variants§
Postgres
PostgreSQL database engine.
PostgreSQL is a powerful, open source object-relational database system. It is known for its reliability, feature richness, and performance. Default port is 5432.
§Features
- Full ACID compliance
- Complex queries and joins
- Foreign key support
- Triggers and views
- Stored procedures
MySQL
MySQL database engine.
MySQL is the world’s most popular open source database. It is widely used for web applications and is known for its speed and reliability. Default port is 3306.
§Features
- ACID compliance (with InnoDB)
- Cross-platform support
- Stored procedures and triggers
- Full-text indexing
SQLite
SQLite database engine.
SQLite is a lightweight, file-based database engine. It requires no server and is embedded directly into the application. Suitable for development, testing, and desktop applications.
§Features
- Serverless architecture
- Zero-configuration
- Single file storage
- Full SQL support
MongoDB
MongoDB database engine.
MongoDB is a document-oriented NoSQL database. It uses JSON-like documents with optional schemas. Default port is 27017.
§Features
- Flexible document schema
- Horizontal scaling
- Rich query language
- Automatic sharding
Redis
Redis database engine.
Redis is an in-memory data structure store. It can be used as a database, cache, and message broker. Default port is 6379.
§Features
- In-memory storage
- Data structures (strings, hashes, lists, sets)
- Pub/Sub messaging
- Persistence options
Trait Implementations§
Source§impl Clone for DatabaseType
impl Clone for DatabaseType
Source§fn clone(&self) -> DatabaseType
fn clone(&self) -> DatabaseType
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for DatabaseType
impl Debug for DatabaseType
Source§impl Default for DatabaseType
impl Default for DatabaseType
Source§impl<'de> Deserialize<'de> for DatabaseType
impl<'de> Deserialize<'de> for DatabaseType
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Display for DatabaseType
impl Display for DatabaseType
Source§impl<'py> IntoPyObject<'py> for DatabaseType
impl<'py> IntoPyObject<'py> for DatabaseType
Source§type Target = DatabaseType
type Target = DatabaseType
Source§type Output = Bound<'py, <DatabaseType as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <DatabaseType as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PartialEq for DatabaseType
impl PartialEq for DatabaseType
Source§impl PyClass for DatabaseType
impl PyClass for DatabaseType
Source§impl PyClassImpl for DatabaseType
impl PyClassImpl for DatabaseType
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = c"Enumeration of supported database engine types.\n\nThis enum represents the different database backends that DMSC can connect to.\nEach database type has specific connection requirements and may use different\nunderlying drivers or client libraries.\n\n## Currently Implemented\n\n| Database Type | Feature Flag | Status |\n|---------------|--------------|--------|\n| PostgreSQL | `postgres` | \xe2\x9c\x85 Available |\n| MySQL | `mysql` | \xe2\x9c\x85 Available |\n| SQLite | `sqlite` | \xe2\x9c\x85 Available |\n| MongoDB | `mongodb` | \xf0\x9f\x94\x9c Planned |\n| Redis | `redis` | \xf0\x9f\x94\x9c Planned |\n\n## Roadmap\n\nMongoDB and Redis support are planned for future releases. The enum variants\nare reserved to maintain API stability when these features are added.\n\n## Usage\n\n```rust,ignore\nuse dmsc::database::DatabaseType;\n\nfn get_preferred_db() -> DatabaseType {\n DatabaseType::Postgres\n}\n```\x00"
const RAW_DOC: &'static CStr = c"Enumeration of supported database engine types.\n\nThis enum represents the different database backends that DMSC can connect to.\nEach database type has specific connection requirements and may use different\nunderlying drivers or client libraries.\n\n## Currently Implemented\n\n| Database Type | Feature Flag | Status |\n|---------------|--------------|--------|\n| PostgreSQL | `postgres` | \xe2\x9c\x85 Available |\n| MySQL | `mysql` | \xe2\x9c\x85 Available |\n| SQLite | `sqlite` | \xe2\x9c\x85 Available |\n| MongoDB | `mongodb` | \xf0\x9f\x94\x9c Planned |\n| Redis | `redis` | \xf0\x9f\x94\x9c Planned |\n\n## Roadmap\n\nMongoDB and Redis support are planned for future releases. The enum variants\nare reserved to maintain API stability when these features are added.\n\n## Usage\n\n```rust,ignore\nuse dmsc::database::DatabaseType;\n\nfn get_preferred_db() -> DatabaseType {\n DatabaseType::Postgres\n}\n```\x00"
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<DatabaseType>
type ThreadChecker = SendablePyClass<DatabaseType>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyTypeInfo for DatabaseType
impl PyTypeInfo for DatabaseType
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.Source§impl Serialize for DatabaseType
impl Serialize for DatabaseType
impl Copy for DatabaseType
impl Eq for DatabaseType
impl ExtractPyClassWithClone for DatabaseType
impl StructuralPartialEq for DatabaseType
Auto Trait Implementations§
impl Freeze for DatabaseType
impl RefUnwindSafe for DatabaseType
impl Send for DatabaseType
impl Sync for DatabaseType
impl Unpin for DatabaseType
impl UnwindSafe for DatabaseType
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::RequestSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more