Ho un piuttosto complesso case
dichiarazione che funziona in MySQL:Scrivere una dichiarazione caso complesso in Sequel?
SELECT # rest of code omitted
CASE WHEN code = 'a' THEN 'x'
WHEN code IN ('m', 'n') THEN 'y'
WHEN class IN ('p', 'q') AND amount < 0 THEN 'z'
ELSE NULL END AS status
FROM # rest of code omitted
Tuttavia, tutti i tentativi di scrivere questo in Sequel hanno fallito. Sto usando questo come un modello:
Sequel.case([[:c, 1], [:d, 2]], 0) # (CASE WHEN "c" THEN 1 WHEN "d" THEN 2 ELSE 0 END)
(da Jeremy Evans' Github)
La mia ipotesi migliore sarebbe:
dataset.select(# rest of code omitted...
[[(:code => 'a'), 'x'],
[(:code => 'b'), 'y'],
[(:class => ['p', 'q'], :amount < 0), 'z']].case(nil).as(:status))
Tutte le idee?
Avete chiesto su [Sequel-talk] (https://groups.google.com/forum/?fromgroups#!forum/sequel-talk)? È qui che si esibiscono Jeremy Evans e i guru. –