课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

CoffeeScript SQLite

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

问题

你需要 Node.js 内部与 SQLite 数据库连接的接口。

解决方案

使用 SQLite 模块。

  1. sqlite = require 'sqlite'
  2. db = new sqlite.Database
  3. # The module uses asynchronous methods,
  4. # so we chain the calls the db.execute
  5. exampleCreate = ->
  6. db.execute "CREATE TABLE snacks (name TEXT(25), flavor TEXT(25))",
  7. (exeErr, rows) ->
  8. throw exeErr if exeErr
  9. exampleInsert()
  10. exampleInsert = ->
  11. db.execute "INSERT INTO snacks (name, flavor) VALUES ($name, $flavor)",
  12. { $name: "Potato Chips", $flavor: "BBQ" },
  13. (exeErr, rows) ->
  14. throw exeErr if exeErr
  15. exampleSelect()
  16. exampleSelect = ->
  17. db.execute "SELECT name, flavor FROM snacks",
  18. (exeErr, rows) ->
  19. throw exeErr if exeErr
  20. console.log rows[0] # => { name: 'Potato Chips', flavor: 'BBQ' }
  21. # :memory: creates a DB in RAM
  22. # You can supply a filepath (like './example.sqlite') to create/open one on disk
  23. db.open ":memory:", (openErr) ->
  24. throw openErr if openErr
  25. exampleCreate()

讨论

你也可以提前准备你的 SQL 查询语句。

  1. sqlite = require 'sqlite'
  2. async = require 'async' # Not required but added to make the example more concise
  3. db = new sqlite.Database
  4. createSQL = "CREATE TABLE drinks (name TEXT(25), price NUM)"
  5. insertSQL = "INSERT INTO drinks (name, price) VALUES (?, ?)"
  6. selectSQL = "SELECT name, price FROM drinks WHERE price < ?"
  7. create = (onFinish) ->
  8. db.execute createSQL, (exeErr) ->
  9. throw exeErr if exeErr
  10. onFinish()
  11. prepareInsert = (name, price, onFinish) ->
  12. db.prepare insertSQL, (prepErr, statement) ->
  13. statement.bindArray [name, price], (bindErr) ->
  14. statement.fetchAll (fetchErr, rows) -> # Called so that it executes the insert
  15. onFinish()
  16. prepareSelect = (onFinish) ->
  17. db.prepare selectSQL, (prepErr, statement) ->
  18. statement.bindArray [1.00], (bindErr) ->
  19. statement.fetchAll (fetchErr, rows) ->
  20. console.log rows[0] # => { name: "Mia's Root Beer", price: 0.75 }
  21. onFinish()
  22. db.open ":memory:", (openErr) ->
  23. async.series([
  24. (onFinish) -> create onFinish,
  25. (onFinish) -> prepareInsert "LunaSqueeze", 7.95, onFinish,
  26. (onFinish) -> prepareInsert "Viking Sparkling Grog", 4.00, onFinish,
  27. (onFinish) -> prepareInsert "Mia's Root Beer", 0.75, onFinish,
  28. (onFinish) -> prepareSelect onFinish
  29. ])

SQL 的 SQLite 版本的以及 node-SQLite 模块文档提供了更完整的信息。

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号