Per esempio, ecco una tabella prodotto in PostgreSQL con status di enum:Come si inserisce un valore enum Postgres utilizzando Clojure JDBC?
create type product_status as enum ('InStock', 'OutOfStock');
create table product (
pid int primary key default nextval('product_pid_seq'),
sku text not null unique,
name text not null,
description text not null,
quantity int not null,
cost numeric(10,2) not null,
price numeric(10,2) not null,
weight numeric(10,2),
status product_status not null
);
tipico codice Clojure per inserire un prodotto sarebbe:
(def prod-12345 {:sku "12345"
:name "My Product"
:description "yada yada yada"
:quantity 100
:cost 42.00
:price 59.00
:weight 0.3
:status "InStock"})
(sql/with-connection db-spec
(sql/insert-record :product prod-12345))
Tuttavia, status
è un enum in modo da non può inserire come una stringa normale senza il cast di un enum:
'InStock'::product_status
so che si può fare con uno stato preparato come:
INSERT INTO product (name, status) VALUES (?, ?::product_status)
Ma c'è un modo per farlo senza utilizzare una dichiarazione preparata?
Penso che @espeed stia chiedendo l'uso della libreria Clojure 'clojure.java.jdbc', non di Java JDBC. –