vapor-docs/build/3.0/databases/sqlite/overview/index.html

2344 lines
57 KiB
HTML

<!DOCTYPE html>
<html lang="en" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<meta name="lang:clipboard.copy" content="Copy to clipboard">
<meta name="lang:clipboard.copied" content="Copied to clipboard">
<meta name="lang:search.language" content="en">
<meta name="lang:search.result.none" content="No matching documents">
<meta name="lang:search.result.one" content="1 matching document">
<meta name="lang:search.result.other" content="# matching documents">
<meta name="lang:search.tokenizer" content="[\s\-]+">
<link rel="shortcut icon" href="../../../assets/images/favicon.png">
<meta name="generator" content="mkdocs-0.17.2, mkdocs-material-2.0.4">
<title>Overview - Vapor Docs</title>
<link rel="stylesheet" href="../../../assets/stylesheets/application-709eec9410.css">
<link rel="stylesheet" href="../../../assets/stylesheets/application-23f75ab9c7.palette.css">
<script src="../../../assets/javascripts/modernizr-e826f8942a.js"></script>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700|Roboto+Mono">
<style>body,input{font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif}code,kbd,pre{font-family:"Roboto Mono","Courier New",Courier,monospace}</style>
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
</head>
<body data-md-color-primary="blue" data-md-color-accent="purple">
<svg class="md-svg">
<defs>
<svg xmlns="http://www.w3.org/2000/svg" width="416" height="448" viewBox="0 0 416 448" id="github"><path fill="currentColor" d="M160 304q0 10-3.125 20.5t-10.75 19T128 352t-18.125-8.5-10.75-19T96 304t3.125-20.5 10.75-19T128 256t18.125 8.5 10.75 19T160 304zm160 0q0 10-3.125 20.5t-10.75 19T288 352t-18.125-8.5-10.75-19T256 304t3.125-20.5 10.75-19T288 256t18.125 8.5 10.75 19T320 304zm40 0q0-30-17.25-51T296 232q-10.25 0-48.75 5.25Q229.5 240 208 240t-39.25-2.75Q130.75 232 120 232q-29.5 0-46.75 21T56 304q0 22 8 38.375t20.25 25.75 30.5 15 35 7.375 37.25 1.75h42q20.5 0 37.25-1.75t35-7.375 30.5-15 20.25-25.75T360 304zm56-44q0 51.75-15.25 82.75-9.5 19.25-26.375 33.25t-35.25 21.5-42.5 11.875-42.875 5.5T212 416q-19.5 0-35.5-.75t-36.875-3.125-38.125-7.5-34.25-12.875T37 371.5t-21.5-28.75Q0 312 0 260q0-59.25 34-99-6.75-20.5-6.75-42.5 0-29 12.75-54.5 27 0 47.5 9.875t47.25 30.875Q171.5 96 212 96q37 0 70 8 26.25-20.5 46.75-30.25T376 64q12.75 25.5 12.75 54.5 0 21.75-6.75 42 34 40 34 99.5z"/></svg>
</defs>
</svg>
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="drawer">
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="search">
<label class="md-overlay" data-md-component="overlay" for="drawer"></label>
<header class="md-header" data-md-component="header">
<nav class="md-header-nav md-grid">
<div class="md-flex">
<div class="md-flex__cell md-flex__cell--shrink">
<a href="../../.." title="Vapor Docs" class="md-header-nav__button md-logo">
<img src="../../../images/droplet-white.svg" width="24" height="24">
</a>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<label class="md-icon md-icon--menu md-header-nav__button" for="drawer"></label>
</div>
<div class="md-flex__cell md-flex__cell--stretch">
<span class="md-flex__ellipsis md-header-nav__title">
<span class="md-header-nav__parent">
Databases
</span>
<span class="md-header-nav__parent">
SQLite
</span>
Overview
</span>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<label class="md-icon md-icon--search md-header-nav__button" for="search"></label>
<div class="md-search" data-md-component="search" role="dialog">
<label class="md-search__overlay" for="search"></label>
<div class="md-search__inner">
<form class="md-search__form" name="search">
<input type="text" class="md-search__input" name="query" required placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="query">
<label class="md-icon md-search__icon" for="search"></label>
<button type="reset" class="md-icon md-search__icon" data-md-component="reset">&#xE5CD;</button>
</form>
<div class="md-search__output">
<div class="md-search__scrollwrap" data-md-scrollfix>
<div class="md-search-result" data-md-component="result">
<div class="md-search-result__meta">
Type to start searching
</div>
<ol class="md-search-result__list"></ol>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<div class="md-header-nav__source">
<a href="http://github.com/vapor/vapor/" title="Go to repository" class="md-source" data-md-source="github">
<div class="md-source__icon">
<svg viewBox="0 0 24 24" width="24" height="24">
<use xlink:href="#github" width="24" height="24"></use>
</svg>
</div>
<div class="md-source__repository">
GitHub
</div>
</a>
</div>
</div>
</div>
</nav>
</header>
<div class="md-container">
<main class="md-main">
<div class="md-main__inner md-grid" data-md-component="container">
<div class="md-sidebar md-sidebar--primary" data-md-component="navigation">
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--primary" data-md-level="0">
<label class="md-nav__title md-nav__title--site" for="drawer">
<span class="md-nav__button md-logo">
<img src="../../../images/droplet-white.svg" width="24" height="24">
</span>
Vapor Docs
</label>
<div class="md-nav__source">
<a href="http://github.com/vapor/vapor/" title="Go to repository" class="md-source" data-md-source="github">
<div class="md-source__icon">
<svg viewBox="0 0 24 24" width="24" height="24">
<use xlink:href="#github" width="24" height="24"></use>
</svg>
</div>
<div class="md-source__repository">
GitHub
</div>
</a>
</div>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../.." title="Overview" class="md-nav__link">
Overview
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-2" type="checkbox" id="nav-2">
<label class="md-nav__link" for="nav-2">
Install
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-2">
Install
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../install/macos/" title="macOS" class="md-nav__link">
macOS
</a>
</li>
<li class="md-nav__item">
<a href="../../../install/ubuntu/" title="Ubuntu" class="md-nav__link">
Ubuntu
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-3" type="checkbox" id="nav-3">
<label class="md-nav__link" for="nav-3">
Getting started
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-3">
Getting started
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../getting-started/hello-world/" title="Hello, world" class="md-nav__link">
Hello, world
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/toolbox/" title="Toolbox" class="md-nav__link">
Toolbox
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/spm/" title="SPM" class="md-nav__link">
SPM
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/xcode/" title="Xcode" class="md-nav__link">
Xcode
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/structure/" title="Folder Structure" class="md-nav__link">
Folder Structure
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/application/" title="Application" class="md-nav__link">
Application
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/controllers/" title="Controllers" class="md-nav__link">
Controllers
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/routing/" title="Routing" class="md-nav__link">
Routing
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/content/" title="Content" class="md-nav__link">
Content
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/futures/" title="Futures" class="md-nav__link">
Futures
</a>
</li>
<li class="md-nav__item">
<a href="../../../getting-started/cloud/" title="Deployment" class="md-nav__link">
Deployment
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-4" type="checkbox" id="nav-4">
<label class="md-nav__link" for="nav-4">
Concepts
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-4">
Concepts
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../concepts/vapor/" title="What is Vapor?" class="md-nav__link">
What is Vapor?
</a>
</li>
<li class="md-nav__item">
<a href="../../../concepts/async/" title="Async" class="md-nav__link">
Async
</a>
</li>
<li class="md-nav__item">
<a href="../../../concepts/codable/" title="Codable" class="md-nav__link">
Codable
</a>
</li>
<li class="md-nav__item">
<a href="../../../concepts/services/" title="Services" class="md-nav__link">
Services
</a>
</li>
<li class="md-nav__item">
<a href="../../../concepts/http/" title="HTTP" class="md-nav__link">
HTTP
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-5" type="checkbox" id="nav-5">
<label class="md-nav__link" for="nav-5">
Async
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-5">
Async
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../async/package/" title="Package" class="md-nav__link">
Package
</a>
</li>
<li class="md-nav__item">
<a href="../../../async/futures-basics/" title="Future Basics" class="md-nav__link">
Future Basics
</a>
</li>
<li class="md-nav__item">
<a href="../../../async/streams-introduction/" title="Streams Introduction" class="md-nav__link">
Streams Introduction
</a>
</li>
<li class="md-nav__item">
<a href="../../../async/streams-basics/" title="Stream Basics" class="md-nav__link">
Stream Basics
</a>
</li>
<li class="md-nav__item">
<a href="../../../async/worker/" title="Worker" class="md-nav__link">
Worker
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-6" type="checkbox" id="nav-6">
<label class="md-nav__link" for="nav-6">
HTTP
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-6">
HTTP
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../http/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/body/" title="Body" class="md-nav__link">
Body
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/client/" title="Client" class="md-nav__link">
Client
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/cookies/" title="Cookies" class="md-nav__link">
Cookies
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/headers/" title="Headers" class="md-nav__link">
Headers
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/method/" title="Methods" class="md-nav__link">
Methods
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/middleware/" title="Middleware" class="md-nav__link">
Middleware
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/multipart/" title="Multipart" class="md-nav__link">
Multipart
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/request/" title="Request" class="md-nav__link">
Request
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/response/" title="Response" class="md-nav__link">
Response
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/responder/" title="Responder" class="md-nav__link">
Responder
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/status/" title="Status codes" class="md-nav__link">
Status codes
</a>
</li>
<li class="md-nav__item">
<a href="../../../http/uri/" title="URI" class="md-nav__link">
URI
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-7" type="checkbox" id="nav-7">
<label class="md-nav__link" for="nav-7">
Fluent
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-7">
Fluent
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-7-1" type="checkbox" id="nav-7-1">
<label class="md-nav__link" for="nav-7-1">
Getting Started
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="2">
<label class="md-nav__title" for="nav-7-1">
Getting Started
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../fluent/getting-started/package/" title="Package" class="md-nav__link">
Package
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/getting-started/provider/" title="Provider" class="md-nav__link">
Provider
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/getting-started/models/" title="Models" class="md-nav__link">
Models
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/getting-started/migrations/" title="Migrations" class="md-nav__link">
Migrations
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/getting-started/querying/" title="Querying" class="md-nav__link">
Querying
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../../../fluent/database/" title="Database" class="md-nav__link">
Database
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/model/" title="Model" class="md-nav__link">
Model
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/query-builder/" title="Query Builder" class="md-nav__link">
Query Builder
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/migration/" title="Migration" class="md-nav__link">
Migration
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/schema-builder/" title="Schema Builder" class="md-nav__link">
Schema Builder
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/relations/" title="Relations" class="md-nav__link">
Relations
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/pivot/" title="Pivot" class="md-nav__link">
Pivot
</a>
</li>
<li class="md-nav__item">
<a href="../../../fluent/transaction/" title="Transaction" class="md-nav__link">
Transaction
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--active md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-8" type="checkbox" id="nav-8" checked>
<label class="md-nav__link" for="nav-8">
Databases
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-8">
Databases
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item md-nav__item--active md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-8-1" type="checkbox" id="nav-8-1" checked>
<label class="md-nav__link" for="nav-8-1">
SQLite
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="2">
<label class="md-nav__title" for="nav-8-1">
SQLite
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../package/" title="Package" class="md-nav__link">
Package
</a>
</li>
<li class="md-nav__item md-nav__item--active">
<input class="md-toggle md-nav__toggle" data-md-toggle="toc" type="checkbox" id="toc">
<label class="md-nav__link md-nav__link--active" for="toc">
Overview
</label>
<a href="./" title="Overview" class="md-nav__link md-nav__link--active">
Overview
</a>
<nav class="md-nav md-nav--secondary">
<label class="md-nav__title" for="toc">Table of contents</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="#database" title="Database" class="md-nav__link">
Database
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#in-memory" title="In Memory" class="md-nav__link">
In Memory
</a>
</li>
<li class="md-nav__item">
<a href="#file-path" title="File path" class="md-nav__link">
File path
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#connection" title="Connection" class="md-nav__link">
Connection
</a>
</li>
<li class="md-nav__item">
<a href="#query" title="Query" class="md-nav__link">
Query
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#binding-values" title="Binding Values" class="md-nav__link">
Binding Values
</a>
</li>
<li class="md-nav__item">
<a href="#output-stream" title="Output Stream" class="md-nav__link">
Output Stream
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#row" title="Row" class="md-nav__link">
Row
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#run" title="Run" class="md-nav__link">
Run
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#all" title="All" class="md-nav__link">
All
</a>
</li>
<li class="md-nav__item">
<a href="#sync" title="Sync" class="md-nav__link">
Sync
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#example" title="Example" class="md-nav__link">
Example
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-8-2" type="checkbox" id="nav-8-2">
<label class="md-nav__link" for="nav-8-2">
MySQL
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="2">
<label class="md-nav__title" for="nav-8-2">
MySQL
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../mysql/package/" title="Package" class="md-nav__link">
Package
</a>
</li>
<li class="md-nav__item">
<a href="../../mysql/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../mysql/setup/" title="Setup" class="md-nav__link">
Setup
</a>
</li>
<li class="md-nav__item">
<a href="../../mysql/basics/" title="Basics" class="md-nav__link">
Basics
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-9" type="checkbox" id="nav-9">
<label class="md-nav__link" for="nav-9">
Redis
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-9">
Redis
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../redis/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../../redis/basics/" title="Basics" class="md-nav__link">
Basics
</a>
</li>
<li class="md-nav__item">
<a href="../../../redis/custom-commands/" title="Custom commands" class="md-nav__link">
Custom commands
</a>
</li>
<li class="md-nav__item">
<a href="../../../redis/pub-sub/" title="Publish and Subscribe" class="md-nav__link">
Publish and Subscribe
</a>
</li>
<li class="md-nav__item">
<a href="../../../redis/pipeline/" title="Pipeline" class="md-nav__link">
Pipeline
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-10" type="checkbox" id="nav-10">
<label class="md-nav__link" for="nav-10">
WebSocket
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-10">
WebSocket
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../websocket/websocket/" title="WebSocket" class="md-nav__link">
WebSocket
</a>
</li>
<li class="md-nav__item">
<a href="../../../websocket/binary-stream/" title="Binary" class="md-nav__link">
Binary
</a>
</li>
<li class="md-nav__item">
<a href="../../../websocket/text-stream/" title="Text" class="md-nav__link">
Text
</a>
</li>
<li class="md-nav__item">
<a href="../../../websocket/client/" title="Client" class="md-nav__link">
Client
</a>
</li>
<li class="md-nav__item">
<a href="../../../websocket/server/" title="Server" class="md-nav__link">
Server
</a>
</li>
<li class="md-nav__item">
<a href="../../../websocket/upgrade/" title="Server Upgrades" class="md-nav__link">
Server Upgrades
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-11" type="checkbox" id="nav-11">
<label class="md-nav__link" for="nav-11">
Routing
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-11">
Routing
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../routing/basics/" title="Basics" class="md-nav__link">
Basics
</a>
</li>
<li class="md-nav__item">
<a href="../../../routing/parameters/" title="Parameters" class="md-nav__link">
Parameters
</a>
</li>
<li class="md-nav__item">
<a href="../../../routing/route/" title="Route" class="md-nav__link">
Route
</a>
</li>
<li class="md-nav__item">
<a href="../../../routing/router/" title="Router" class="md-nav__link">
Router
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-12" type="checkbox" id="nav-12">
<label class="md-nav__link" for="nav-12">
Services
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-12">
Services
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../services/getting-started/" title="Getting Started" class="md-nav__link">
Getting Started
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-13" type="checkbox" id="nav-13">
<label class="md-nav__link" for="nav-13">
JWT
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-13">
JWT
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../jwt/jws/" title="Signed Tokens" class="md-nav__link">
Signed Tokens
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-14" type="checkbox" id="nav-14">
<label class="md-nav__link" for="nav-14">
Crypto
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-14">
Crypto
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../crypto/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../../crypto/base64/" title="Base64" class="md-nav__link">
Base64
</a>
</li>
<li class="md-nav__item">
<a href="../../../crypto/hash/" title="Hashes" class="md-nav__link">
Hashes
</a>
</li>
<li class="md-nav__item">
<a href="../../../crypto/mac/" title="Message authentication" class="md-nav__link">
Message authentication
</a>
</li>
<li class="md-nav__item">
<a href="../../../crypto/passwords/" title="Password hashing" class="md-nav__link">
Password hashing
</a>
</li>
<li class="md-nav__item">
<a href="../../../crypto/random/" title="Random" class="md-nav__link">
Random
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-15" type="checkbox" id="nav-15">
<label class="md-nav__link" for="nav-15">
Sockets
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-15">
Sockets
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../sockets/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../../sockets/tcp-client/" title="TCP Client" class="md-nav__link">
TCP Client
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-16" type="checkbox" id="nav-16">
<label class="md-nav__link" for="nav-16">
Testing
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-16">
Testing
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../testing/getting-started/" title="Getting Started" class="md-nav__link">
Getting Started
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-17" type="checkbox" id="nav-17">
<label class="md-nav__link" for="nav-17">
Security
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-17">
Security
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../security/" title="Index" class="md-nav__link">
Index
</a>
</li>
<li class="md-nav__item">
<a href="../../../security/dos/" title="Denial of Service" class="md-nav__link">
Denial of Service
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-18" type="checkbox" id="nav-18">
<label class="md-nav__link" for="nav-18">
Additional information
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-18">
Additional information
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../supplementary/architecture/" title="Architecture" class="md-nav__link">
Architecture
</a>
</li>
<li class="md-nav__item">
<a href="../../../supplementary/performance/" title="Performance" class="md-nav__link">
Performance
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-toggle md-nav__toggle" data-md-toggle="nav-19" type="checkbox" id="nav-19">
<label class="md-nav__link" for="nav-19">
Version (3.0-alpha)
</label>
<nav class="md-nav" data-md-component="collapsible" data-md-level="1">
<label class="md-nav__title" for="nav-19">
Version (3.0-alpha)
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../../version/1_5/" title="1.5" class="md-nav__link">
1.5
</a>
</li>
<li class="md-nav__item">
<a href="../../../version/2_0/" title="2.0" class="md-nav__link">
2.0
</a>
</li>
<li class="md-nav__item">
<a href="../../../version/3_0/" title="3.0-alpha" class="md-nav__link">
3.0-alpha
</a>
</li>
<li class="md-nav__item">
<a href="../../../version/support/" title="Support" class="md-nav__link">
Support
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-sidebar md-sidebar--secondary" data-md-component="toc">
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--secondary">
<label class="md-nav__title" for="toc">Table of contents</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="#database" title="Database" class="md-nav__link">
Database
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#in-memory" title="In Memory" class="md-nav__link">
In Memory
</a>
</li>
<li class="md-nav__item">
<a href="#file-path" title="File path" class="md-nav__link">
File path
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#connection" title="Connection" class="md-nav__link">
Connection
</a>
</li>
<li class="md-nav__item">
<a href="#query" title="Query" class="md-nav__link">
Query
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#binding-values" title="Binding Values" class="md-nav__link">
Binding Values
</a>
</li>
<li class="md-nav__item">
<a href="#output-stream" title="Output Stream" class="md-nav__link">
Output Stream
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#row" title="Row" class="md-nav__link">
Row
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#run" title="Run" class="md-nav__link">
Run
</a>
<nav class="md-nav">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#all" title="All" class="md-nav__link">
All
</a>
</li>
<li class="md-nav__item">
<a href="#sync" title="Sync" class="md-nav__link">
Sync
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#example" title="Example" class="md-nav__link">
Example
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-content">
<article class="md-content__inner md-typeset">
<a href="https://github.com/vapor/documentation/edit/beta/3.0/docs/databases/sqlite/overview.md" title="Edit this page" class="md-icon md-content__icon">&#xE3C9;</a>
<h1 id="sqlite-overview">SQLite Overview<a class="headerlink" href="#sqlite-overview" title="Permanent link">&para;</a></h1>
<p>Let's dive into the <a href="https://github.com/vapor/sqlite">vapor/sqlite</a> package and
see how to connect to and query a database.</p>
<div class="admonition warning">
<p class="admonition-title">Warning</p>
<p>This documentation provides an overview for the SQLite API.
If you are using SQLite with Fluent, you will likely never need to use
this API. Use <a href="../fluent/overview.md">Fluent's APIs</a> instead.</p>
</div>
<p>Follow the instructions in the <a href="../package/">package</a> section to add the SQLite package to your project. Once its added, you should be able to use <code>import SQLite.</code></p>
<h2 id="database">Database<a class="headerlink" href="#database" title="Permanent link">&para;</a></h2>
<p>The first step to making a query is to create a <code>Database</code>.</p>
<h3 id="in-memory">In Memory<a class="headerlink" href="#in-memory" title="Permanent link">&para;</a></h3>
<p>In-memory SQLite databases are great for testing as they aren't persisted between application boots.</p>
<div class="codehilite"><pre><span></span><span class="kd">import</span> <span class="nc">SQLite</span>
<span class="kd">let</span> <span class="nv">db</span> <span class="p">=</span> <span class="n">Database</span><span class="p">(</span><span class="n">storage</span><span class="p">:</span> <span class="p">.</span><span class="n">memory</span><span class="p">)</span>
</pre></div>
<h3 id="file-path">File path<a class="headerlink" href="#file-path" title="Permanent link">&para;</a></h3>
<p>SQLite requires a single file to persist the database contents.</p>
<div class="codehilite"><pre><span></span><span class="kd">import</span> <span class="nc">SQLite</span>
<span class="kd">let</span> <span class="nv">db</span> <span class="p">=</span> <span class="n">Database</span><span class="p">(</span><span class="n">storage</span><span class="p">:</span> <span class="p">.</span><span class="n">file</span><span class="p">(</span><span class="n">path</span><span class="p">:</span> <span class="s">&quot;/tmp/db.sqlite&quot;</span><span class="p">))</span>
</pre></div>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>If the database file does not already exist, it will be created.</p>
</div>
<h2 id="connection">Connection<a class="headerlink" href="#connection" title="Permanent link">&para;</a></h2>
<p>Once you have initialized your database, you can create a connection.</p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">conn</span> <span class="p">=</span> <span class="k">try</span> <span class="n">db</span><span class="p">.</span><span class="n">makeConnection</span><span class="p">(</span><span class="n">on</span><span class="p">:</span> <span class="p">.</span><span class="n">global</span><span class="p">())</span>
</pre></div>
<div class="admonition note">
<p class="admonition-title">Note</p>
<p>Pay special attention to which <code>DispatchQueue</code> you pass to <code>makeConnection(on:)</code>.
This will be the queue SQLite calls you back on.</p>
</div>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>If you are using SQLite with Vapor, make sure to pass the <a href="async/worker.md">worker</a>'s queue here.</p>
</div>
<h2 id="query">Query<a class="headerlink" href="#query" title="Permanent link">&para;</a></h2>
<p>Once you have a <code>Connection</code>, you can use it to create a <code>Query</code>.</p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">query</span> <span class="p">=</span> <span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;SELECT * FROM users&quot;</span><span class="p">)</span>
</pre></div>
<h3 id="binding-values">Binding Values<a class="headerlink" href="#binding-values" title="Permanent link">&para;</a></h3>
<p>If you are executing a query that has input values, you should bind these using parameters. </p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">query</span> <span class="p">=</span> <span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;INSERT INTO users (name, age) VALUES (?, ?)&quot;</span><span class="p">)</span>
<span class="n">query</span><span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="s">&quot;Albert&quot;</span><span class="p">)</span>
<span class="n">query</span><span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="mi">138</span><span class="p">)</span>
</pre></div>
<p>You can also bind values using method chaining.</p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">query</span> <span class="p">=</span> <span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;INSERT INTO users (name, age) VALUES (?, ?)&quot;</span><span class="p">)</span>
<span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="s">&quot;Albert&quot;</span><span class="p">)</span>
<span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="mi">138</span><span class="p">)</span>
</pre></div>
<h3 id="output-stream">Output Stream<a class="headerlink" href="#output-stream" title="Permanent link">&para;</a></h3>
<p>If you expect output from your query, you must attach a stream. The easiest way
to do this is by using the <code>drain</code> convenience.</p>
<div class="codehilite"><pre><span></span><span class="n">query</span><span class="p">.</span><span class="n">drain</span> <span class="p">{</span> <span class="n">row</span> <span class="k">in</span>
<span class="bp">print</span><span class="p">(</span><span class="n">row</span><span class="p">)</span>
<span class="p">}</span>
</pre></div>
<p>You can also use <code>drain(into:)</code> and pass in a custom <code>InputStream</code> to capture the query's results.</p>
<h4 id="row">Row<a class="headerlink" href="#row" title="Permanent link">&para;</a></h4>
<p>The <code>Query</code> will output <code>Row</code>s. These are simple structs.</p>
<div class="codehilite"><pre><span></span><span class="kd">struct</span> <span class="nc">Row</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nv">fields</span><span class="p">:</span> <span class="p">[</span><span class="nb">String</span><span class="p">:</span> <span class="n">Field</span><span class="p">]</span>
<span class="kd">subscript</span><span class="p">(</span><span class="n">field</span><span class="p">:</span> <span class="nb">String</span><span class="p">)</span> <span class="p">-&gt;</span> <span class="n">Data</span><span class="p">?</span> <span class="p">{</span> <span class="kr">get</span> <span class="p">}</span>
<span class="p">}</span>
</pre></div>
<p>You can subscript a <code>Row</code> object to get the optional <code>Data</code>.</p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">nameData</span> <span class="p">=</span> <span class="n">row</span><span class="p">[</span><span class="s">&quot;name&quot;</span><span class="p">]</span> <span class="c1">// Data?</span>
</pre></div>
<p><code>Data</code> is an enum that contains all possible types of SQLite data.</p>
<div class="codehilite"><pre><span></span><span class="kd">public</span> <span class="kd">enum</span> <span class="nc">Data</span> <span class="p">{</span>
<span class="k">case</span> <span class="n">integer</span><span class="p">(</span><span class="nb">Int</span><span class="p">)</span>
<span class="k">case</span> <span class="n">float</span><span class="p">(</span><span class="nb">Double</span><span class="p">)</span>
<span class="k">case</span> <span class="n">text</span><span class="p">(</span><span class="nb">String</span><span class="p">)</span>
<span class="k">case</span> <span class="n">blob</span><span class="p">(</span><span class="n">Foundation</span><span class="p">.</span><span class="n">Data</span><span class="p">)</span>
<span class="k">case</span> <span class="n">null</span>
<span class="p">}</span>
</pre></div>
<p>For each option, there are convenience properties for casting the <code>Data</code> enum.</p>
<div class="codehilite"><pre><span></span><span class="kd">let</span> <span class="nv">name</span> <span class="p">=</span> <span class="n">row</span><span class="p">[</span><span class="s">&quot;name&quot;</span><span class="p">]?.</span><span class="n">text</span> <span class="c1">// String</span>
</pre></div>
<h3 id="run">Run<a class="headerlink" href="#run" title="Permanent link">&para;</a></h3>
<p>Once your query is ready to execute, you simply call <code>.execute()</code>. This returns a <code>Future&lt;Void&gt;</code>
that will be completed when the query is done executing.</p>
<div class="codehilite"><pre><span></span><span class="n">query</span><span class="p">.</span><span class="n">execute</span><span class="p">().</span><span class="n">then</span> <span class="p">{</span>
<span class="bp">print</span><span class="p">(</span><span class="s">&quot;done!&quot;</span><span class="p">)</span>
<span class="p">}</span>
</pre></div>
<h4 id="all">All<a class="headerlink" href="#all" title="Permanent link">&para;</a></h4>
<p>If you simply want to fetch all of the results, you can use the <code>.all()</code> convenience.
This will automatically create a stream and return a future containing your results.</p>
<div class="codehilite"><pre><span></span><span class="n">query</span><span class="p">.</span><span class="n">all</span><span class="p">().</span><span class="n">then</span> <span class="p">{</span> <span class="n">rows</span> <span class="k">in</span>
<span class="bp">print</span><span class="p">(</span><span class="n">rows</span><span class="p">)</span>
<span class="p">}</span>
</pre></div>
<h4 id="sync">Sync<a class="headerlink" href="#sync" title="Permanent link">&para;</a></h4>
<p>For situations where blocking is appropriate (perhaps in tests) you can use <code>.sync()</code> to block
until the query's results are ready and return them directly.</p>
<div class="codehilite"><pre><span></span><span class="c1">// don&#39;t do this unless blocking is OK</span>
<span class="kd">let</span> <span class="nv">rows</span> <span class="p">=</span> <span class="k">try</span> <span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;SELECT * FROM users&quot;</span><span class="p">).</span><span class="n">sync</span><span class="p">()</span>
</pre></div>
<h3 id="example">Example<a class="headerlink" href="#example" title="Permanent link">&para;</a></h3>
<p>Now for the complete example: </p>
<div class="codehilite"><pre><span></span><span class="kd">import</span> <span class="nc">SQLite</span>
<span class="kd">let</span> <span class="nv">db</span> <span class="p">=</span> <span class="n">Database</span><span class="p">(</span><span class="n">storage</span><span class="p">:</span> <span class="p">.</span><span class="n">memory</span><span class="p">)</span>
<span class="kd">let</span> <span class="nv">conn</span> <span class="p">=</span> <span class="k">try</span> <span class="n">db</span><span class="p">.</span><span class="n">makeConnection</span><span class="p">(</span><span class="n">on</span><span class="p">:</span> <span class="p">.</span><span class="n">global</span><span class="p">())</span> <span class="c1">// take care to use correct queue</span>
<span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;SELECT * FROM users&quot;</span><span class="p">)</span>
<span class="p">.</span><span class="n">all</span><span class="p">()</span>
<span class="p">.</span><span class="n">then</span> <span class="p">{</span> <span class="n">rows</span> <span class="k">in</span>
<span class="bp">print</span><span class="p">(</span><span class="n">rows</span><span class="p">)</span>
<span class="p">}</span>
<span class="p">.</span><span class="k">catch</span> <span class="p">{</span> <span class="n">err</span> <span class="k">in</span>
<span class="bp">print</span><span class="p">(</span><span class="n">err</span><span class="p">)</span>
<span class="p">}</span>
<span class="c1">// wait for results</span>
</pre></div>
<p>An example with values being bound:</p>
<div class="codehilite"><pre><span></span><span class="kd">import</span> <span class="nc">SQLite</span>
<span class="kd">let</span> <span class="nv">db</span> <span class="p">=</span> <span class="n">Database</span><span class="p">(</span><span class="n">storage</span><span class="p">:</span> <span class="p">.</span><span class="n">memory</span><span class="p">)</span>
<span class="kd">let</span> <span class="nv">conn</span> <span class="p">=</span> <span class="k">try</span> <span class="n">db</span><span class="p">.</span><span class="n">makeConnection</span><span class="p">(</span><span class="n">on</span><span class="p">:</span> <span class="p">.</span><span class="n">global</span><span class="p">())</span> <span class="c1">// take care to use correct queue</span>
<span class="n">conn</span><span class="p">.</span><span class="n">query</span><span class="p">(</span><span class="s">&quot;INSERT INTO users (name, age) VALUES (?, ?)&quot;</span><span class="p">)</span>
<span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="s">&quot;Albert&quot;</span><span class="p">)</span>
<span class="p">.</span><span class="n">bind</span><span class="p">(</span><span class="mi">138</span><span class="p">)</span>
<span class="p">.</span><span class="n">execute</span><span class="p">()</span>
<span class="p">.</span><span class="n">then</span> <span class="p">{</span>
<span class="bp">print</span><span class="p">(</span><span class="s">&quot;done&quot;</span><span class="p">)</span>
<span class="p">}</span>
<span class="p">.</span><span class="k">catch</span> <span class="p">{</span> <span class="n">err</span> <span class="k">in</span>
<span class="bp">print</span><span class="p">(</span><span class="n">err</span><span class="p">)</span>
<span class="p">}</span>
<span class="c1">// wait for results</span>
</pre></div>
</article>
</div>
</div>
</main>
<footer class="md-footer">
<div class="md-footer-nav">
<nav class="md-footer-nav__inner md-grid">
<a href="../package/" title="Package" class="md-flex md-footer-nav__link md-footer-nav__link--prev" rel="prev">
<div class="md-flex__cell md-flex__cell--shrink">
<i class="md-icon md-icon--arrow-back md-footer-nav__button"></i>
</div>
<div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title">
<span class="md-flex__ellipsis">
<span class="md-footer-nav__direction">
Previous
</span>
Package
</span>
</div>
</a>
<a href="../../mysql/package/" title="Package" class="md-flex md-footer-nav__link md-footer-nav__link--next" rel="next">
<div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title">
<span class="md-flex__ellipsis">
<span class="md-footer-nav__direction">
Next
</span>
Package
</span>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<i class="md-icon md-icon--arrow-forward md-footer-nav__button"></i>
</div>
</a>
</nav>
</div>
<div class="md-footer-meta md-typeset">
<div class="md-footer-meta__inner md-grid">
<div class="md-footer-copyright">
<div class="md-footer-copyright__highlight">
Copyright &copy; 2017 Qutheory, LLC
</div>
powered by
<a href="http://www.mkdocs.org" title="MkDocs">MkDocs</a>
and
<a href="http://squidfunk.github.io/mkdocs-material/" title="Material for MkDocs">
Material for MkDocs</a>
</div>
<div class="md-footer-social">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<a href="https://twitter.com/@codevapor" class="md-footer-social__link fa fa-twitter"></a>
<a href="http://vapor.team/" class="md-footer-social__link fa fa-slack"></a>
<a href="https://github.com/vapor" class="md-footer-social__link fa fa-github"></a>
</div>
</div>
</div>
</footer>
</div>
<script src="../../../assets/javascripts/application-8e4952e681.js"></script>
<script>app.initialize({version:"0.17.2",url:{base:"../../.."}})</script>
<script>!function(e,t,a,n,o,c,i){e.GoogleAnalyticsObject=o,e[o]=e[o]||function(){(e[o].q=e[o].q||[]).push(arguments)},e[o].l=1*new Date,c=t.createElement(a),i=t.getElementsByTagName(a)[0],c.async=1,c.src=n,i.parentNode.insertBefore(c,i)}(window,document,"script","https://www.google-analytics.com/analytics.js","ga"),ga("create","UA-76177358-4","auto"),ga("set","anonymizeIp",!0),ga("send","pageview");var links=document.getElementsByTagName("a");Array.prototype.map.call(links,function(e){e.host!=document.location.host&&e.addEventListener("click",function(){var t=e.getAttribute("data-md-action")||"follow";ga("send","event","outbound",t,e.href)})});var query=document.forms.search.query;query.addEventListener("blur",function(){if(this.value){var e=document.location.pathname;ga("send","pageview",e+"?q="+this.value)}})</script>
</body>
</html>