MongoDB

MongoDB库函数是在mongo-c语言库的基础上封装而成,能够为Swift轻松访问MongoDB服务器提供便利。

该工具库软件包是由Swift软件包管理器编译而来,是 Perfect项目的组成部分, 被设计为可以独立使用,不依赖PerfectLib或其它任何组件。

请确保安装并激活了最新版本的Swift 4.0 toolchain。

不同操作系统平台的准备工作

OS X

该工具包需要通过Homebrew安装mongo-c。

安装Homebrew:

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

安装mongo-c:

brew install mongo-c-driver

Linux

确保已经安装了libmongoc。

sudo apt-get install libmongoc

在您的项目里引用MongoDB Driver驱动

请在Package.swift增加对该驱动的依存关系。

.Package(
    url:"https://github.com/PerfectlySoft/Perfect-MongoDB.git",
    majorVersion: 3
    )

关于如何在您的项目中使用Perfect函数库,详见参考手册《使用Swift软件包管理器编译项目

快速上手

通过以下命令快速克隆一个空白的Perfect项目模板:

git clone https://github.com/PerfectlySoft/PerfectTemplate.git
cd PerfectTemplate

在Package.swift文件中增加依存关系:

let package = Package(
    name: "PerfectTemplate",
    targets: [],
    dependencies: [
        .Package(url:"https://github.com/PerfectlySoft/Perfect.git", versions: Version(0,0,0)..<Version(10,0,0)),
        .Package(url:"https://github.com/PerfectlySoft/Perfect-MongoDB.git", versions: Version(0,0,0)..<Version(10,0,0))
    ]
)

创建Xcode项目:

swift package generate-xcodeproj

从Xcode中打开自动生成的PerfectTemplate.xcodeproj项目文件。

该项目会编译然后在本地端口8181启动一个服务器。

⚠️注意⚠️ 每次向项目追加依存关系时,必须要打开Swift软件包管理器重新创建一个新的Xcode项目文件。注意任何对该文件的手工修改都会被丢弃。

在您的项目中声明MongoDB

请在您的Perfect项目源程序开头声明并导入MongoDB函数库:

import MongoDB

创建一个MongoDB数据库连接

创建到MongoDB服务器连接时,需要相应的URL,内容是IP或域名,并可选择端口号。

确定具体的连接URL之后,参考以下例子打开连接:

let client = try! MongoClient(uri: "mongodb://localhost")

其中“localhost”请自行替换为实际的服务器地址。

定义一个数据库

一旦服务器连接成功,即可选择具体数据库:

let db = client.getDatabase(name: "test")

定义一个MongoDB集合D

请采用以下方式定义和操作MongoDB集合:

let collection = db.getCollection(name: "testcollection")

关闭活动的服务器连接

一旦服务器连接成功,建议采用defer块方式进行滞后关闭

defer {
    collection.close()
    db.close()
    client.close()
}

执行检索

请使用find方法在集合中检索全部有关文档:

    let fnd = collection.find(query: BSON())

    // 初始化一个空数组用于接收格式化结果
    var arr = [String]()

    // “fnd”被定义为MongoCursor的检索记录游标,是可以遍历的
    for x in fnd! {
        arr.append(x.asString)
    }

有关MongoDB Collections集合类,请参考MongoDB Collections