Schema
The Schema
type is used to define the schema for a model in the RushDB SDK. It describes the structure and validation rules for the data fields of a model.
Type Definition
type Schema = Record<
string,
{
default?: SchemaDefaultValue;
multiple?: boolean;
required?: boolean;
type: PropertyType;
uniq?: boolean;
}
>;
Properties
default
- Type:
MaybePromise<PropertyValue>
- Optional: Yes
The initial value of the field if no value is provided during record creation. It can be a static value or a function that returns a value asynchronously, allowing for dynamic default values.
multiple
- Type:
boolean
- Optional: Yes
Indicates whether the field can hold multiple values (array) or just a single value.
required
- Type:
boolean
- Optional: Yes
Specifies whether a field is mandatory. If set to true
, you cannot create a record without providing a value for this field.
type
- Type:
'boolean' | 'datetime' | 'null' | 'number' | 'string'
- Optional: No
Defines the data type of the field. The type determines the available search operators and how data is validated and stored.
uniq
- Type:
boolean
- Optional: Yes
If set to true
, the field must have a unique value across all records in the database, useful for fields like email addresses or custom identifiers.
Example Usage
Here is an example of how to define a schema using Schema
:
const AuthorSchema: Schema = {
name: { type: 'string', required: true },
email: { type: 'string', uniq: true },
age: { type: 'number', default: 30 },
isActive: { type: 'boolean', default: true }
};
In this example:
name
is a required string field.email
is a unique string field.age
is a number field with a default value of 30.isActive
is a boolean field with a default value of true.