-
Notifications
You must be signed in to change notification settings - Fork 190
Working with tables
Before doing anything else you'll probably want to define your tables.
Syntax:
var myTable = sql.define(tableConf);
tableConf is the definition for your table. It can have the following fields:
- name: The name of the table (required)
- columns: column definitions (see below)
- columnWhiteList: TODO: define this parameter
- isTemporary: true if this is a temporary table. Default value: false
- snakeToCamel: if true column names will be converted to camelCase (e.g. needs_more_info will become needsMoreInfo, but the original will be used in generating queries)
There are two valid formats for your Column Definitions:
In this configuration the key is the column name, the value is the column spec.
Table.define({
name: "AwesomeTable",
columns: {
id: {dataType: "serial primary key"},
numCol: {dataType: "decimal"},
notes: {dataType: "text"}
}
});
In this configuration an array of column definitions are used. The column definition can be a column spec object or a string; if a string then no type will be registered.
Table.define({
name: "AwesomeTable",
columns: [
{name: "id", dataType: "serial primary key"},
"numCol",
{name: "notes", dataType: "text"}
]
});
The column specification can contain the following fields:
- name: Not needed w/ Object-style column definitions; this is the name of the field.
- dataType: specifies the SQL datatype of the field
- primaryKey: true if this field should be part of the primary key
TODO: What other fields are valid here?
You can generate the SQL for creating a table from any complete table definition; the primary requirement is that your defintion contain field types.
var createSqlStr = Table.create().toQuery().text;
You can generate the SQL for dropping a table from any table definition.
var createSqlStr = Table.drop().toQuery().text;
This project needs a lot better documentation; if you know how to use it well, please consider adding some information to this page or to other wiki pages