[英]Clojure PostgreSQL JDBC keep getting error executing query
我希望有人可以幫助我,
所以我正在用clojure和postgresql構建數據庫支持的網站,但是我一直出錯。 以下是REPL上的代碼和錯誤:
(ns app.config-postgre
(require [clojure.java.jdbc :as sql]))
(def db1
{:classname "org.postgresql.Driver"
:subprotocol "postgresql"
:subname "//localhost:5432/dbname"
:username "username"
:password "password})
;;that's not the real username and password, the real one is right
這里是導致錯誤的代碼:
(sql/insert! db1 :user123
{:username "user" :password "pass" :user-id "1"})
;;PSQLException ERROR: syntax error at or near "user"
Position: 43 org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse (QueryExecutorImpl.java:2157)
和
(sql/execute! db1 ["INSERT INTO user123 VALUES ('{\"user\", \"pass\" ,1}')"])
;;PSQLException ERROR: null value in column "password" violates not-null constraint
Detail: Failing row contains ({user,pass,1}, null, null). org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse (QueryExecutorImpl.java:2157)
和
(sql/execute! db1 ["INSERT INTO user123 VALUES ('{\"user\"},{\"pass\"},{1}')"])
;;PSQLException ERROR: malformed array literal: "{"user"},{"pass"},{1}"
Detail: Junk after closing right brace.
Position: 29 org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse (QueryExecutorImpl.java:2157)
和
(sql/execute! db1 ["INSERT INTO user123 VALUES ('\"user\",\"pass\",1')"])
;;PSQLException ERROR: malformed array literal: ""user","pass",1"
Detail: Array value must start with "{" or dimension information.
Position: 29 org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse (QueryExecutorImpl.java:2157)
和
(sql/execute! db1 ["INSERT INTO user123 VALUES ('user','pass',1)"])
;;PSQLException ERROR: malformed array literal: "user"
Detail: Array value must start with "{" or dimension information.
Position: 29 org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse (QueryExecutorImpl.java:2157)
有什么建議嗎? 先感謝您
編輯表user123的模式:
CREATE TABLE user123
(
username character varying(100)[] NOT NULL,
password character varying(100)[] NOT NULL,
"user-id" integer NOT NULL,
CONSTRAINT user_pkey PRIMARY KEY ("user-id")
)
使用(sql/execute! db1 ["INSERT INTO user123 VALUES (?, ?, ?)" "user" "pass" 1])
(sql/execute! db1 ["INSERT INTO user123 VALUES ({'user'}, {'pass'}, 1);"])
我認為您應該在數據庫規范中將:username更改為: user 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.