lisp连接mysql_Common Lisp 操作Mysql

Common Lisp 通过CFFI可以调用其它语言的接口,如此,Common Lisp可以快速开发各种应用程序,本文将讲述在ubuntu系统下的一个简单的Common Lisp与mysql交互的实例。

准备

安装CFFIsudo apt-get install cl-cffi

安装CL-MYSQL

sudo apt-get install cl-sql-mysql

安装MYSQLsudo apt-get install mysql-server

安装quicklispwget http://beta.quicklisp.org/quicklisp.lisp

开始

启动slime或sbcl(本例使用slime).

进入slime:

M+x slime

slime下加载quicklisp:

CL-USER> (load "quicklisp.lisp")

CL-USER> (quicklisp-quickstart:install)

CL-USER> (ql:add-to-init-file)

加载cffi和cl-mysql:

CL-USER> (ql:quickload "cffi")

CL-USER> (ql:quickload "cl-mysl")

8fb84025a6d1e4270c92bce1bfcccba7.png

定义试验用的mysql操作包:

(defpackage :com.casic.mysql-oper

(:use :common-lisp :cl-mysql :cl-mysql-system))

#

(注:本实例涉及到的mysql操作分别包含于cl-mysql包和cl-mysql-system包内,为避免经常性地切换包,建立一包含以上两包的自定义包mysql-oper)。

切换到自定义包:

CL-USER> (in-package :com.casic.mysql-oper)

#

链接mysql数据库:

MYSQL-OPER> (connect :host "localhost" :user "root" :password "")

#

进入现有数据库test:

MYSQL-OPER> (query "use test")

(((0) NIL))

创建新表person_info:

MYSQL-OPER> (query "create table person_info\(id int\)")

(((0) NIL))

插入数据:

MYSQL-OPER> (query "create table person-info\(id int\)")

(((1) NIL)) 也可以处理multi-statements,多语句:

MYSQL-OPER> (query "insert into person_info values \(2\);insert into person_info

values \(3\);insert into person_info values \(4\)")

(((1) NIL) ((1) NIL) ((1) NIL))

查询数据:

MYSQL-OPER> (query "select * from person_info")

((((1) (2) (3) (4)) (("id" :LONG 32768)))) 更新数据:

MYSQK-OPER> (query "update person_info set id=6 where id=4")

(((1) NIL))

MYSQL-OPER> (query "select * from person_info")

((((1) (2) (3) (5)) (("id" "LONG 32768)) 删除数据:

MYSQL-OPER> (query "delete from person_info where id=5")

(((1) NIL))

MYSQL-OPER> (query "select * from person_info")

((((1) (2) (3)) (("id" :LONG 32768))

至此,Common Lisp通过cffi和cl-mysql操作mysql数据库的基本功能完成。您可以像使用php一样操作mysql数据库建立自己的应用程序了!

来源:oschina

链接:https://my.oschina.net/u/1011760/blog/130787

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值