Improve insert-missing-data-and-return-all-ids
Use exec-query-with-null-handling to distinguish NULL values, change it to just take a list of fields and remove the handlers. Also, add a sets-of-data? parameter so that this can be used licenses.
This commit is contained in:
parent
1441942200
commit
80010a8a1b
4 changed files with 88 additions and 60 deletions
|
|
@ -12,10 +12,7 @@
|
||||||
(insert-missing-data-and-return-all-ids
|
(insert-missing-data-and-return-all-ids
|
||||||
conn
|
conn
|
||||||
"lint_checkers"
|
"lint_checkers"
|
||||||
`((name . ,(lambda (value)
|
'(name description network_dependent)
|
||||||
(quote-string (symbol->string value))))
|
|
||||||
(description . ,quote-string)
|
|
||||||
(network_dependent . ,value->sql-boolean))
|
|
||||||
lint-checkers-data))
|
lint-checkers-data))
|
||||||
|
|
||||||
(define (lint-warning-count-by-lint-checker-for-revision conn commit-hash)
|
(define (lint-warning-count-by-lint-checker-for-revision conn commit-hash)
|
||||||
|
|
|
||||||
|
|
@ -12,8 +12,7 @@
|
||||||
(insert-missing-data-and-return-all-ids
|
(insert-missing-data-and-return-all-ids
|
||||||
conn
|
conn
|
||||||
"lint_warning_messages"
|
"lint_warning_messages"
|
||||||
`((locale . ,quote-string)
|
'(locale message)
|
||||||
(message . ,quote-string))
|
|
||||||
(map (match-lambda
|
(map (match-lambda
|
||||||
((locale . message)
|
((locale . message)
|
||||||
(list locale message)))
|
(list locale message)))
|
||||||
|
|
|
||||||
|
|
@ -13,10 +13,7 @@
|
||||||
(insert-missing-data-and-return-all-ids
|
(insert-missing-data-and-return-all-ids
|
||||||
conn
|
conn
|
||||||
"lint_warnings"
|
"lint_warnings"
|
||||||
`((lint_checker_id . ,identity)
|
'(lint_checker_id package_id location_id lint_warning_message_set_id)
|
||||||
(package_id . ,identity)
|
|
||||||
(location_id . ,identity)
|
|
||||||
(lint_warning_message_set_id . ,identity))
|
|
||||||
lint-warnings-data))
|
lint-warnings-data))
|
||||||
|
|
||||||
(define (insert-guix-revision-lint-warnings conn
|
(define (insert-guix-revision-lint-warnings conn
|
||||||
|
|
|
||||||
|
|
@ -4,9 +4,10 @@
|
||||||
#:use-module (ice-9 vlist)
|
#:use-module (ice-9 vlist)
|
||||||
#:use-module (ice-9 receive)
|
#:use-module (ice-9 receive)
|
||||||
#:use-module (squee)
|
#:use-module (squee)
|
||||||
#:export (quote-string
|
#:use-module (guix-data-service database)
|
||||||
|
#:export (NULL
|
||||||
|
quote-string
|
||||||
value->quoted-string-or-null
|
value->quoted-string-or-null
|
||||||
value->sql-boolean
|
|
||||||
non-empty-string-or-false
|
non-empty-string-or-false
|
||||||
exec-query->vhash
|
exec-query->vhash
|
||||||
two-lists->vhash
|
two-lists->vhash
|
||||||
|
|
@ -14,6 +15,8 @@
|
||||||
group-list-by-first-n-fields
|
group-list-by-first-n-fields
|
||||||
insert-missing-data-and-return-all-ids))
|
insert-missing-data-and-return-all-ids))
|
||||||
|
|
||||||
|
(define NULL '())
|
||||||
|
|
||||||
(define (quote-string s)
|
(define (quote-string s)
|
||||||
(string-append "$STR$" s "$STR$"))
|
(string-append "$STR$" s "$STR$"))
|
||||||
|
|
||||||
|
|
@ -22,16 +25,6 @@
|
||||||
(string-append "$STR$" value "$STR$")
|
(string-append "$STR$" value "$STR$")
|
||||||
"NULL"))
|
"NULL"))
|
||||||
|
|
||||||
(define (value->sql-boolean v)
|
|
||||||
(match v
|
|
||||||
((? boolean? x)
|
|
||||||
(if x "TRUE" "FALSE"))
|
|
||||||
((? string? x)
|
|
||||||
(if (or (string=? x "t")
|
|
||||||
(string=? x "TRUE"))
|
|
||||||
"TRUE"
|
|
||||||
"FALSE"))))
|
|
||||||
|
|
||||||
(define (non-empty-string-or-false s)
|
(define (non-empty-string-or-false s)
|
||||||
(if (string? s)
|
(if (string? s)
|
||||||
(if (string-null? s)
|
(if (string-null? s)
|
||||||
|
|
@ -45,7 +38,7 @@
|
||||||
(value-function row)
|
(value-function row)
|
||||||
result))
|
result))
|
||||||
vlist-null
|
vlist-null
|
||||||
(exec-query conn query)))
|
(exec-query-with-null-handling conn query)))
|
||||||
|
|
||||||
(define (two-lists->vhash l1 l2)
|
(define (two-lists->vhash l1 l2)
|
||||||
(fold (lambda (key value result)
|
(fold (lambda (key value result)
|
||||||
|
|
@ -78,63 +71,79 @@
|
||||||
'()
|
'()
|
||||||
lists))
|
lists))
|
||||||
|
|
||||||
(define (insert-missing-data-and-return-all-ids
|
(define* (insert-missing-data-and-return-all-ids
|
||||||
conn
|
conn
|
||||||
table-name
|
table-name
|
||||||
fields-and-handlers
|
fields
|
||||||
data)
|
data
|
||||||
(define fields (map symbol->string
|
#:key
|
||||||
(map first fields-and-handlers)))
|
sets-of-data?)
|
||||||
|
(define field-strings
|
||||||
|
(map symbol->string fields))
|
||||||
|
|
||||||
(define handlers (map cdr fields-and-handlers))
|
(define value->sql
|
||||||
|
(match-lambda
|
||||||
|
((? string? s)
|
||||||
|
(string-append "$STR$" s "$STR$"))
|
||||||
|
((? symbol? s)
|
||||||
|
(string-append "$STR$"
|
||||||
|
(symbol->string s)
|
||||||
|
"$STR$"))
|
||||||
|
((? number? n)
|
||||||
|
(number->string n))
|
||||||
|
((? boolean? b)
|
||||||
|
(if b "TRUE" "FALSE"))
|
||||||
|
((? null?)
|
||||||
|
"NULL")
|
||||||
|
(v
|
||||||
|
(error
|
||||||
|
(simple-format #f "error: unknown type for value: ~A" v)))))
|
||||||
|
|
||||||
(define select-query
|
(define select-query
|
||||||
(string-append
|
(string-append
|
||||||
"SELECT id, "
|
"SELECT id, "
|
||||||
(string-join (map (lambda (field)
|
(string-join (map (lambda (field)
|
||||||
(string-append table-name "." field))
|
(string-append table-name "." field))
|
||||||
fields)
|
field-strings)
|
||||||
", ")
|
", ")
|
||||||
" FROM " table-name
|
" FROM " table-name
|
||||||
" JOIN (VALUES "
|
" JOIN (VALUES "
|
||||||
;; TODO This doesn't handle NULL values
|
|
||||||
(string-join
|
(string-join
|
||||||
(map
|
(map
|
||||||
(lambda (field-values)
|
(lambda (field-values)
|
||||||
(string-append
|
(string-append
|
||||||
"("
|
"("
|
||||||
(string-join
|
(string-join (map value->sql field-values) ",")
|
||||||
(map (lambda (value handler)
|
|
||||||
(handler value))
|
|
||||||
field-values
|
|
||||||
handlers)
|
|
||||||
",")
|
|
||||||
")"))
|
")"))
|
||||||
data)
|
(if sets-of-data?
|
||||||
|
(delete-duplicates
|
||||||
|
(concatenate data))
|
||||||
|
data))
|
||||||
", ")
|
", ")
|
||||||
") AS vals (" (string-join fields ", ") ") "
|
") AS vals (" (string-join field-strings ", ") ") "
|
||||||
"ON "
|
"ON "
|
||||||
(string-join
|
(string-join
|
||||||
(map (lambda (field)
|
(map (lambda (field)
|
||||||
(string-append
|
(string-append
|
||||||
table-name "." field " = vals." field))
|
"(" table-name "." field " = vals." field
|
||||||
fields)
|
" OR (" table-name "." field " IS NULL AND"
|
||||||
|
" vals." field " IS NULL))"))
|
||||||
|
field-strings)
|
||||||
" AND ")))
|
" AND ")))
|
||||||
|
|
||||||
(define (insert-sql missing-data)
|
(define (insert-sql missing-data)
|
||||||
(string-append
|
(string-append
|
||||||
"INSERT INTO " table-name " ("
|
"INSERT INTO " table-name " ("
|
||||||
(string-join fields ", ")
|
(string-join field-strings ", ")
|
||||||
") VALUES "
|
") VALUES "
|
||||||
(string-join
|
(string-join
|
||||||
(map (lambda (field-values)
|
(map (lambda (field-values)
|
||||||
(string-append
|
(string-append
|
||||||
"("
|
"("
|
||||||
(string-join
|
(string-join
|
||||||
(map (lambda (value handler)
|
(map (lambda (value)
|
||||||
(handler value))
|
(value->sql value))
|
||||||
field-values
|
field-values)
|
||||||
handlers)
|
|
||||||
", ")
|
", ")
|
||||||
")"))
|
")"))
|
||||||
missing-data)
|
missing-data)
|
||||||
|
|
@ -150,9 +159,16 @@
|
||||||
((? symbol? s)
|
((? symbol? s)
|
||||||
(symbol->string s))
|
(symbol->string s))
|
||||||
((? string? s)
|
((? string? s)
|
||||||
s))
|
s)
|
||||||
|
((? null? s)
|
||||||
|
;; exec-query-with-null-handling specifies NULL values as '()
|
||||||
|
'()))
|
||||||
data))
|
data))
|
||||||
|
|
||||||
|
(define (sort-ids ids)
|
||||||
|
(map number->string
|
||||||
|
(sort (map string->number ids) <)))
|
||||||
|
|
||||||
(let* ((existing-entries
|
(let* ((existing-entries
|
||||||
(exec-query->vhash conn
|
(exec-query->vhash conn
|
||||||
select-query
|
select-query
|
||||||
|
|
@ -160,9 +176,14 @@
|
||||||
first))
|
first))
|
||||||
(missing-entries
|
(missing-entries
|
||||||
(filter (lambda (field-values)
|
(filter (lambda (field-values)
|
||||||
(not (vhash-assoc (normalise-values field-values)
|
(not (vhash-assoc
|
||||||
existing-entries)))
|
;; Normalise at this point, so that the proper value
|
||||||
data))
|
;; to insert is carried forward
|
||||||
|
(normalise-values field-values)
|
||||||
|
existing-entries)))
|
||||||
|
(if sets-of-data?
|
||||||
|
(delete-duplicates (concatenate data))
|
||||||
|
data)))
|
||||||
(new-entries
|
(new-entries
|
||||||
(if (null? missing-entries)
|
(if (null? missing-entries)
|
||||||
'()
|
'()
|
||||||
|
|
@ -172,11 +193,25 @@
|
||||||
(two-lists->vhash missing-entries
|
(two-lists->vhash missing-entries
|
||||||
new-entries)))
|
new-entries)))
|
||||||
|
|
||||||
(map (lambda (field-values)
|
(if sets-of-data?
|
||||||
(cdr
|
(map (lambda (field-value-lists)
|
||||||
(or (vhash-assoc (normalise-values field-values)
|
;; Normalise the result at this point, ensuring that the id's
|
||||||
existing-entries)
|
;; in the set are sorted
|
||||||
(vhash-assoc field-values
|
(sort-ids
|
||||||
new-entries-lookup-vhash)
|
(map (lambda (field-values)
|
||||||
(error "missing entry" field-values))))
|
(cdr
|
||||||
data)))
|
(or (vhash-assoc (normalise-values field-values)
|
||||||
|
existing-entries)
|
||||||
|
(vhash-assoc field-values
|
||||||
|
new-entries-lookup-vhash)
|
||||||
|
(error "missing entry" field-values))))
|
||||||
|
field-value-lists)))
|
||||||
|
data)
|
||||||
|
(map (lambda (field-values)
|
||||||
|
(cdr
|
||||||
|
(or (vhash-assoc (normalise-values field-values)
|
||||||
|
existing-entries)
|
||||||
|
(vhash-assoc field-values
|
||||||
|
new-entries-lookup-vhash)
|
||||||
|
(error "missing entry" field-values))))
|
||||||
|
data))))
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue