Swift 如何访问 MongoDB

perfect_github_2_0_0.jpg

Perfect 开源项目 参与 Perfect 开发 Slack 在线协同html

MongoDB

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

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

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

不一样操做系统平台的准备工做

OS X

该工具包须要经过Homebrew安装mongo-c。数据库

安装Homebrew:swift

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

安装mongo-c:数组

brew install mongo-c

Linux

确保已经安装了libmongoc。xcode

sudo apt-get install libmongoc

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

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

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

关于如何在您的项目中使用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

长按二维码关注Perfect 官网
微信号:PerfectlySoft (公司名)
qr.jpg

若是须要帮助,请注册咱们在Slack上的中文频道: http://perfect.ly/

更多内容请查看 PerfeclySoft 源码仓库 https://github.com/PerfectlyS...
详细内容请点击如下连接,或选择 http://www.perfect.org 官网。

相关文章
相关标签/搜索