1
0

query.cljs 1.3 KB

123456789101112131415161718192021222324252627282930313233
  1. (ns query
  2. "An example script that queries any db graph from the commandline e.g.
  3. $ yarn -s nbb-logseq script/query.cljs db-name '[:find (pull ?b [:block/name :block/content]) :where [?b :block/created-at]]'"
  4. (:require [datascript.core :as d]
  5. [clojure.edn :as edn]
  6. [logseq.db.sqlite.db :as sqlite-db]
  7. [logseq.db.sqlite.cli :as sqlite-cli]
  8. [logseq.db.rules :as rules]
  9. [nbb.core :as nbb]
  10. ["path" :as path]
  11. ["os" :as os]))
  12. (defn read-graph
  13. "The db graph bare version of gp-cli/parse-graph"
  14. [graph-name]
  15. (let [graphs-dir (path/join (os/homedir) "logseq/graphs")]
  16. (sqlite-db/open-db! graphs-dir graph-name)
  17. (sqlite-cli/read-graph graph-name)))
  18. (defn -main [args]
  19. (when (not= 2 (count args))
  20. (println "Usage: $0 GRAPH QUERY")
  21. (js/process.exit 1))
  22. (let [[graph-name query*] args
  23. conn (read-graph graph-name)
  24. query (into (edn/read-string query*) [:in '$ '%]) ;; assumes no :in are in queries
  25. results (mapv first (d/q query @conn (rules/extract-rules rules/db-query-dsl-rules)))]
  26. (println "DB contains" (count (d/datoms @conn :eavt)) "datoms")
  27. (prn results)))
  28. (when (= nbb/*file* (:file (meta #'-main)))
  29. (-main *command-line-args*))