clojure.contrib.sql
模块有一个create-table
函数,它接受表名和规范列表,如下所示:
(sql/create-table :services
[:id :serial "PRIMARY KEY"]
[:service_name :varchar "NOT NULL"]
[:pass_hash :varchar "NOT NULL"]
[:token :varchar "NOT NULL"])
如果我一次又一次地重复使用相同的列,有没有办法定义这样的内容?
(def same-columns
[:id :serial "PRIMARY KEY"]
[:service_name :varchar "NOT NULL"]
[:pass_hash :varchar "NOT NULL"]
[:token :varchar "NOT NULL"])
当我尝试在REPL中运行它时出现错误,因为它向def
传递了太多参数。
答案 0 :(得分:3)
您可以使用apply:
(def same-columns [[:id :serial "PRIMARY KEY"]
[:service_name :varchar "NOT NULL"]
[:pass_hash :varchar "NOT NULL"]
[:token :varchar "NOT NULL"]])
(apply sql/create-table
:services
same-columns)
如果您有其他列,也可以添加这些列:
(apply sql/create-table
:services
[:some-column :varchar "NOT NULL"]
same-columns)