database: Add 'last-insert-rowid' procedure.

This commit is contained in:
Mathieu Lirzin 2016-07-22 13:13:52 +02:00
parent 447d9f7ba8
commit 8ad3ce782f
No known key found for this signature in database
GPG Key ID: 0ADEE10094604D37
1 changed files with 5 additions and 4 deletions

View File

@ -98,15 +98,16 @@ database object."
(map (λ (key) (or (assq-ref alst key) default-value))
keys))
(define (last-insert-rowid db)
(vector-ref (car (sqlite-exec db "SELECT last_insert_rowid();"))
0))
(define (db-add-evaluation db job)
"Store a derivation result in database DB and return its ID."
(sqlite-exec db "insert into build (job_spec, drv) values ('~A', '~A');"
(assq-ref job #:job-name)
(assq-ref job #:derivation))
(let* ((stmt (sqlite-prepare db "select last_insert_rowid() from build;"))
(res (sqlite-step stmt)))
(sqlite-finalize stmt)
(vector-ref res 0)))
(last-insert-rowid db))
(define (db-get-evaluation db id)
"Retrieve a job in database DB which corresponds to ID."