metodisering
This commit is contained in:
parent
fdc02cdfcc
commit
a771b49ca7
66
db.lisp
66
db.lisp
|
@ -4,40 +4,38 @@
|
|||
|
||||
(connect-toplevel "worblehat" "horace" "" "localhost")
|
||||
|
||||
(:create-table book
|
||||
((isbn :type string :primary-key t)
|
||||
(title :type string)
|
||||
(year :type integer)
|
||||
(publisher :type string)
|
||||
(udc :type string)
|
||||
(edition :type integer)
|
||||
(picture :type string)
|
||||
(description :type (or db-null text))
|
||||
(language :type string)
|
||||
(review :type integer :unique t)
|
||||
(author :type integer :unique t))
|
||||
(:foreign-key (review) (review id))
|
||||
(:foreign-key (author) (author id)))
|
||||
|
||||
(:create-table review
|
||||
((id :type integer :primary-key t :references (book :cascade :cascade))
|
||||
(review :type text)
|
||||
(grade :type integer)
|
||||
(author :type string)))
|
||||
|
||||
(:create-table author
|
||||
((id :type integer :primary-key t :references (book :cascade :cascade))
|
||||
(surname :type string)
|
||||
(lastname :type string)))
|
||||
|
||||
(:create-table copy
|
||||
((id :type integer :primary-key t)
|
||||
(shelf :type string)
|
||||
(rented :type boolean)
|
||||
(owner :type string)
|
||||
(condition :type string)
|
||||
(book :type string))
|
||||
(:foreign-key (book) (book isbn)))
|
||||
(defun create-tables ()
|
||||
(:create-table book
|
||||
((isbn :type string :primary-key t)
|
||||
(title :type string)
|
||||
(year :type integer)
|
||||
(publisher :type string)
|
||||
(udc :type string)
|
||||
(edition :type integer)
|
||||
(picture :type string)
|
||||
(description :type (or db-null text))
|
||||
(language :type string)
|
||||
(review :type integer :unique t)
|
||||
(author :type integer :unique t))
|
||||
(:foreign-key (review) (review id))
|
||||
(:foreign-key (author) (author id)))
|
||||
(:create-table review
|
||||
((id :type integer :primary-key t :references (book :cascade :cascade))
|
||||
(review :type text)
|
||||
(grade :type integer)
|
||||
(author :type string)))
|
||||
(:create-table author
|
||||
((id :type integer :primary-key t :references (book :cascade :cascade))
|
||||
(surname :type string)
|
||||
(lastname :type string)))
|
||||
(:create-table copy
|
||||
((id :type integer :primary-key t)
|
||||
(shelf :type string)
|
||||
(rented :type boolean)
|
||||
(owner :type string)
|
||||
(condition :type string)
|
||||
(book :type string))
|
||||
(:foreign-key (book) (book isbn))))
|
||||
|
||||
|
||||
;(defclass book ()
|
||||
|
|
Reference in New Issue