v/vlib/orm
Enzo c8471528ce
fmt: format long sum-types with a line for each type (#11461)
2021-09-10 20:56:55 +03:00
..
README.md
orm.v fmt: format long sum-types with a line for each type (#11461) 2021-09-10 20:56:55 +03:00
orm_fn_test.v all: introduce `isize` and `usize` (#11437) 2021-09-08 05:53:39 +03:00
orm_test.v orm: fix time (#11026) 2021-08-03 05:17:00 +03:00

README.md

ORM

Attributes

Structs

  • [table: 'name'] sets a custom table name

Fields

  • [primary] sets the field as the primary key
  • [unique] sets the field as unique
  • [unique: 'foo'] adds the field to a unique group
  • [skip] field will be skipped
  • [sql: type] sets the type which is used in sql (special type serial)
  • [sql: 'name'] sets a custom column name for the field

Usage

struct Foo {
    id   int    [primary; sql: serial]
    name string [nonull]
}

Create

sql db {
    create table Foo
}

Drop

sql db {
    drop table Foo
}

Insert

var := Foo{
    name: 'abc'
}

sql db {
    insert var into Foo
}

Update

sql db {
    update Foo set name = 'cde' where name == 'abc'
}

Delete

sql db {
    delete from Foo where id > 10
}

Select

result := sql db {
    select from Foo where id == 1
}
result := sql db {
    select from Foo where id > 1 limit 5
}
result := sql db {
    select from Foo where id > 1 order by id
}