curl操作CouchDB

couchdb 服务器地址: 127.0.0.1

端口:5984

添加数据库

  • 连接到couchdb

    curl -X GET http://127.0.0.1:5984

    {"couchdb":"Welcome","uuid":"1c81fc63d761c82c4f48bac34afd5eb8","version":"1.6.0","vendor":{"name":"The Apache Software Foundation","version":"1.6.0"}}

  • 创建一个数据库db1

    curl -X PUT http://127.0.0.1:5984/db1

    {"ok":true}

  • 创建数据库 db2

    curl -X PUT http://127.0.0.1:5984/db2

    {"ok":true}

  • 列出当前所有的数据库

    curl -X GET http://127.0.0.1:5984/_all_dbs

    ["_replicator","_users","db1","db2"]

  • 删除db2数据库

    curl -X DELETE http://127.0.0.1:5984/db2

    {"ok":true}

    删除成功

数据库操作

  • 向数据库添加数据

    首先,获取一个uuid 
    curl -X GET http://127.0.0.1:5984/_uuids 
    {"uuids":["1925a2a284289df9b55b390525001ca1"]} 
    注意:每次得到的uuid不一样。 
    获取10个uuid: curl -X GET http://127.0.0.1:5984/_uuids?count=10

    使用uuid作为键插入一条数据 
    curl -X PUT http://127.0.0.1:5984/db1/1925a2a284289df9b55b390525001ca1 -d ‘{"title":"test","content":"this is test!"}‘ 
    {"ok":true,"id":"1925a2a284289df9b55b390525001ca1","rev":"1-4d3e6350fdcc39f7b482c4cab8ff5d9a"}

  • 更新记录

    curl -X PUT http://127.0.0.1:5984/db1/1925a2a284289df9b55b390525001ca1 -d ‘{"title":"test","content":"this is test!modifyied!"}‘

    {"error":"conflict","reason":"Document update conflict."} 
    失败了。因为,couchdb是按版本提交的,同一个源提交多次会造成一定的混乱。所以,其采用了版本进行控制。

    curl -X PUT http://127.0.0.1:5984/db1/1925a2a284289df9b55b390525001ca1 -d ‘{"_rev":"1-4d3e6350fdcc39f7b482c4cab8ff5d9a","title":"test","content":"this is test!"}‘

    {"ok":true,"id":"1925a2a284289df9b55b390525001ca1","rev":"2-f6f24194b29981316f2412e288cda320"} 
    这样就没有问题了。

  • 获取记录

    curl -X GET http://127.0.0.1:5984/db1/1925a2a284289df9b55b390525001ca1

    {"_id":"1925a2a284289df9b55b390525001ca1","_rev":"2-f6f24194b29981316f2412e288cda320","title":"test","content":"this is test!"}

  • 列出db1库下的所有文档

    curl -X GET http://127.0.0.1:5984/db1/_all_docs

    {"total_rows":2,"offset":0,"rows":[ 
    {"id":"1925a2a284289df9b55b390525001ca1","key":"1925a2a284289df9b55b390525001ca1","value":{"rev":"2-f6f24194b29981316f2412e288cda320"}}, 
    {"id":"1925a2a284289df9b55b390525002c29","key":"1925a2a284289df9b55b390525002c29","value":{"rev":"1-4a1158c264f8cc636e1fc54a7a696de6"}} 
    ]}

  • 删除记录

    curl -X DELETE http://127.0.0.1:5984/db1/1925a2a284289df9b55b390525001ca1?rev=2-f6f24194b29981316f2412e288cda320

上传附件

curl -X PUT http://127.0.0.1:5984/db1/40dab8a067c56aef572307dd1f0119c8 -d ‘{"title":"test","content":"this is test!"}‘ 
curl -X PUT http://127.0.0.1:5984/db1/40dab8a067c56aef572307dd1f0119c8/atwork.jpg?rev=2-2739352689 --data-binary @atwork.jpg -H "Content-Type:image/jpg" 
atwork.jpg是当前目录下的图片文件。

数据库复制

    • 本地复制

      curl -X PUT http://127.0.0.1:5984/albums-replica 
      curl -X POST http://127.0.0.1:5984/_replicate -d ‘{"source":"albums","target":"albums-replica"}‘ -H "Content-Type: application/json"

    • 本地到远端复制

      curl -X POST http://127.0.0.1:5984/_replicate -d ‘{"source":"albums","target":"http://example.org:5984/albums-replica"}‘ -H "Content-Type:application/json"

      如果远端服务器有密码,可以采用这种格式:http://username:[email protected]:5984/demo

    • 远端到本地

      curl -X POST http://127.0.0.1:5984/_replicate -d ‘{"source":"http://example.org:5984/albums-replica","target":"albums"}‘ -H "Content-Type:application/json"

    • 远端到远端

      curl -X POST http://127.0.0.1:5984/_replicate -d ‘{"source":"http://example.org:5984/albums","target":"http://example.org:5984/albums-replica"}‘ -H "Content-Type: application/json"

时间: 2024-11-08 18:17:54

curl操作CouchDB的相关文章

使用curl操作openstack swift

openstack官网有专门的开发者文档介绍如何使用curl操作swift(http://docs.openstack.org/api/openstack-object-storage/1.0/content/),本文做了些翻译工作并在自己创建的swift集群中做了实验,如果希望阅读完整的swift开发者文档,请到官网阅读,内容还是很详细的,本文只是向希望了解swift对象存储的朋友做个直观的展示. 1. Curl Curl是一个命令行工具,能够通过命令行发送和接受http请求和响应,这使得它能

ElasticSearch笔记整理(二):CURL操作、ES插件、集群安装与核心概念

[TOC] CURL操作 CURL简介 curl是利用URL语法在命令行方式下工作的开源文件传输工具,使用curl可以简单实现常见的get/post请求.简单的认为是可以在命令行下面访问url的一个工具.在centos的默认库里面是有curl工具的,如果没有请yum安装即可. curl -X 指定http的请求方法 有HEAD GET POST PUT DELETE -d 指定要传输的数据 -H 指定http请求头信息 curl创建索引库 curl -XPUT http://<ip>:9200

ElasticSearch之CURL操作(有空再去整理)

https://www.cnblogs.com/jing1617/p/8060421.html CURL的操作    curl是利用URL语法在命令行方式下工作的开源文件传输工具,使用curl可以简单实现常见的get/post请求.简单的认为是可以在命令行下面访问url的一个工具.在centos的默认库里面是有curl工具的,如果没有请yum安装即可.     curl     -X 指定http的请求方法 有HEAD GET POST PUT DELETE     -d 指定要传输的数据   

window下使用curl操作elasticsearch

1.下载curlzip,https://curl.haxx.se/download.html; 2.解压,在bin文件夹中找到curl.exe,右键"以管理员身份运行",cmd e: 换盘符:出现E:\Work\curl-7.46.0-win64\curl-7.46.0-win64\bin: 3.curl localhost:9200/ 查询集群的健康状态 curl localhost:9200/_cat/health?v 查询结点的列表 curl localhost:9200/_ca

CURL操作与实践

CURL是liunx系统的一个命令行工具,目的是进行数据抓取:现在CURL已经在非常多的系统中使用,WIN用户可以使用DOS版本的CURL命令操作,操作方法很简单,就是在CMD窗口中找到CURL文件夹,执行CURL命令即可,CMD中操作CURL不是本文讲解的重点,本文讲解PHP中的CURL: 一,PHP中安装CURL 1,PHP.INI中找到 ;extension=php_curl.dll,去掉分号,如果没有自己添加一行: 2,本文使用的是phpstudy,在其他菜单->PHP扩展及设置->P

elasticsearch(5) curl 操作elasticsearch

创建索引之前可以对索引做初始化操作, 比如指定shards数量以及replicas的数量.     library为索引的名称 CURL -XPUT 'http://192.168.1.10:9200/library/' -d '{ "settings": { "index": { "number_of_shards": 5, "number_of_replicas": 1 } } }' CURL -XGET 'http://

ElasticSearch之CURL操作

CURL的操作    curl是利用URL语法在命令行方式下工作的开源文件传输工具,使用curl可以简单实现常见的get/post请求.简单的认为是可以在命令行下面访问url的一个工具.在centos的默认库里面是有curl工具的,如果没有请yum安装即可.     curl     -X 指定http的请求方法 有HEAD GET POST PUT DELETE     -d 指定要传输的数据     -H 指定http请求头信息     浏览ES服务器         curl -XGET

ElasticSearch记录(2)curl操作

新建和删除 Index 新建 Index,可以直接向 Elastic 服务器发出 PUT 请求.下面的例子是新建一个名叫weather的 Index. curl -XPUT http://192.168.239.101:9200/weather/ 服务器返回一个 JSON 对象,里面的acknowledged字段表示操作成功. { "acknowledged":true, "shards_acknowledged":true } 然后,我们发出 DELETE 请求,

php curl操作

<?php // $curl=curl_init(); // $url="http://localhost/cc/get.php?lo=ccc"; // curl_setopt($curl,CURLOPT_URL, $url); // curl_exec($curl); // curl_close($curl); $curl=curl_init(); $url="http://localhost/cc/post.php"; curl_setopt($curl,