2019-08-20 17:32:39 +03:00
|
|
|
module main
|
|
|
|
|
|
|
|
import pg
|
|
|
|
|
|
|
|
struct Customer {
|
|
|
|
id int
|
|
|
|
name string
|
|
|
|
nr_orders int
|
|
|
|
country string
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
db := pg.connect(pg.Config{host: '127.0.0.1' user: 'myuser' dbname: 'mydb'})
|
|
|
|
|
|
|
|
nr_customers := db.select count from Customer
|
|
|
|
println('Total customers: $nr_customers')
|
|
|
|
|
|
|
|
// V syntax can be used to build queries
|
|
|
|
println('------------------------------------------------------------------------')
|
2019-08-22 22:33:57 +03:00
|
|
|
bg_customers := db.select from Customer where country == 'Bulgaria' && id != 2
|
2019-08-20 17:32:39 +03:00
|
|
|
for customer in bg_customers {
|
|
|
|
println('$customer.country | $customer.id - $customer.name')
|
|
|
|
}
|
|
|
|
|
|
|
|
println('------------------------------------------------------------------------')
|
2019-08-22 22:33:57 +03:00
|
|
|
ru_customers := db.select from Customer where country == 'Russia'
|
2019-08-20 17:32:39 +03:00
|
|
|
for customer in ru_customers {
|
|
|
|
println('$customer.country | $customer.id - $customer.name')
|
|
|
|
}
|
|
|
|
|
|
|
|
// by adding `limit 1` we tell V that there will be only one object
|
|
|
|
println('------------------------------------------------------------------------')
|
2019-08-22 22:33:57 +03:00
|
|
|
existing := db.select from Customer where id == 1 limit 1 or { panic(err) }
|
2019-08-20 17:32:39 +03:00
|
|
|
println('Existing customer name: $existing.name')
|
|
|
|
println('Existing customer full information:')
|
|
|
|
println(existing)
|
|
|
|
|
|
|
|
println('------------------------------------------------------------------------')
|
|
|
|
q := Customer{}
|
|
|
|
for {
|
2019-08-22 22:33:57 +03:00
|
|
|
anon := db.select from Customer where id == 12345 && name == q.name && nr_orders > q.nr_orders limit 1 or { eprintln('No such customer. Error: $err') break }
|
2019-08-20 17:32:39 +03:00
|
|
|
println('Non existing customer name: $anon.name')
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: insert a new customer
|
|
|
|
/*
|
|
|
|
nc := Customer{
|
|
|
|
name: 'John Doe'
|
|
|
|
nr_orders: 10
|
|
|
|
}
|
|
|
|
db.insert(nc)
|
|
|
|
*/
|
2019-08-22 22:33:57 +03:00
|
|
|
|
|
|
|
|
2019-08-20 17:32:39 +03:00
|
|
|
}
|