CouchDB - Hızlı Kılavuz

Veritabanı yönetim sistemi, verilerin depolanması ve alınması için mekanizma sağlar. RDBMS (İlişkisel Veritabanı yönetim Sistemleri), OLAP (Çevrimiçi Analitik İşleme Sistemleri) ve NoSQL olmak üzere üç ana veritabanı yönetim sistemi türü vardır.

RDBMS

RDBMS, İlişkisel Veritabanı Yönetim Sisteminin kısaltmasıdır. RDBMS, SQL'in ve MS SQL Server, IBM DB2, Oracle, MySQL ve Microsoft Access gibi tüm modern veritabanı sistemlerinin temelidir.

İlişkisel veritabanı yönetim sistemi (RDBMS), EF Codd tarafından sunulan ilişkisel modeli temel alan bir veritabanı yönetim sistemidir (DBMS).

RDBMS'deki veriler, adı verilen veritabanı nesnelerinde saklanır. tables. Tablo, ilgili veri girişlerinin bir koleksiyonudur ve sütun ve satırlardan oluşur. Yalnızca yapılandırılmış verileri depolar.

OLAP

Çevrimiçi Analitik İşleme Sunucusu (OLAP), çok boyutlu veri modeline dayanmaktadır. Yöneticilerin ve analistlerin bilgiye hızlı, tutarlı ve etkileşimli erişim yoluyla bilgi edinmesine olanak tanır.

NoSQL Veritabanları

Bir NoSQL veritabanı (bazen Yalnızca SQL Değil olarak da adlandırılır), ilişkisel veritabanlarında kullanılan tablo ilişkilerinden başka verileri depolamak ve almak için bir mekanizma sağlayan bir veritabanıdır. Bu veritabanları şemasızdır, kolay çoğaltmayı destekler, basit API'ye sahiptir, sonunda tutarlıdır ve büyük miktarda veriyi (büyük veri) işleyebilir.

Bir NoSQL veritabanının birincil amacı aşağıdakilere sahip olmaktır -

  • Tasarımın sadeliği,
  • Yatay ölçekleme ve
  • Kullanılabilirlik üzerinde daha hassas kontrol.

NoSQL veritabanları, ilişkisel veritabanlarına kıyasla farklı veri yapıları kullanır. NoSQL'de bazı işlemleri daha hızlı hale getirir. Belirli bir NoSQL veritabanının uygunluğu, çözmesi gereken soruna bağlıdır. Bu veritabanları hem yapılandırılmış verileri hem de ses dosyaları, video dosyaları, belgeler vb. Gibi yapılandırılmamış verileri depolar. Bu NoSQL veritabanları üç tipte sınıflandırılır ve aşağıda açıklanmıştır.

Key-value Store- Bu veritabanları, verileri anahtar-değer çiftlerinde depolamak için tasarlanmıştır ve bu veritabanları herhangi bir şemaya sahip olmayacaktır. Bu veritabanlarında, her veri değeri indekslenmiş bir anahtardan ve bu anahtar için bir değerden oluşur.

Örnekler - BerkeleyDB, Cassandra, DynamoDB, Riak.

Column Store- Bu veritabanlarında veriler, veri sütunlarında gruplanmış hücrelerde depolanır ve bu sütunlar ayrıca Sütun aileleri halinde gruplandırılır. Bu sütun aileleri herhangi bir sayıda sütun içerebilir.

Örnekler - BigTable, HBase ve HyperTable.

Document Store- Bunlar, "belgelerin" daha karmaşık veriler içerdiği anahtar-değer depolarının temel fikri üzerine geliştirilmiş veritabanlarıdır. Burada her belgeye, belgeyi almak için kullanılan benzersiz bir anahtar atanır. Bunlar, yarı yapılandırılmış veriler olarak da bilinen belge odaklı bilgileri depolamak, almak ve yönetmek için tasarlanmıştır.

Örnekler - CouchDB ve MongoDB.

CouchDB nedir?

CouchDB, Apache yazılım kuruluşu tarafından geliştirilen açık kaynaklı bir veritabanıdır. Odak noktası, web'i kucaklayan kullanım kolaylığıdır. Bir NoSQL belge deposu veritabanıdır.

Verileri (dokümanları) depolamak için JSON, dokümanları dönüştürmek için sorgu dili olarak java betiği, dokümanlara erişmek için api için http protokolü, web tarayıcısı ile indeksleri sorgulama kullanır. 2005 yılında yayınlanan bir multi master uygulamasıdır ve 2008 yılında apache projesi haline gelmiştir.

Neden CouchDB?

  • CouchDB, veritabanı ile kolayca iletişim kurmaya yardımcı olan HTTP tabanlı bir REST API'ye sahiptir. Ve HTTP kaynaklarının ve yöntemlerinin (GET, PUT, DELETE) basit yapısının anlaşılması ve kullanılması kolaydır.

  • Verileri esnek belge tabanlı yapıda depoladığımız için verilerin yapısı konusunda endişelenmenize gerek yok.

  • Kullanıcılara, bilgilerin sorgulanmasına, birleştirilmesine ve filtrelenmesine olanak tanıyan güçlü veri eşleme sağlanır.

  • CouchDB, veri tabanları ve makineler arasında verileri kopyalayabileceğiniz, paylaşabileceğiniz ve senkronize edebileceğiniz, kullanımı kolay çoğaltma sağlar.

Veri örneği

  • Veritabanı, CouchDB'deki en dıştaki veri yapısı / kabıdır.

  • Her veritabanı bağımsız belgelerden oluşan bir koleksiyondur.

  • Her belge kendi verilerini ve kendi kendine yeten şemasını korur.

  • Belge meta verileri, veritabanlarının bağlantısı kesilirken oluşan farklılıkları birleştirmeyi mümkün kılan revizyon bilgilerini içerir.

  • CouchDB, yazma sırasında veritabanı alanını kilitleme ihtiyacını ortadan kaldırmak için çoklu sürüm eşzamanlılık kontrolü uygular.

CouchDB'nin Özellikleri: İçeriği Azaltın

Belge saklama

CouchDB bir belge saklama NoSQL veritabanıdır. Belgeleri benzersiz adlarla saklama olanağı sağlar ve ayrıca veritabanı belgelerini okumak ve güncellemek (eklemek, düzenlemek, silmek) için RESTful HTTP API adlı bir API sağlar.

CouchDB'de belgeler birincil veri birimidir ve ayrıca meta verileri de içerir. Belge alanları benzersiz bir şekilde adlandırılır ve çeşitli türlerde değerler içerir (metin, sayı, Boole, listeler vb.) Ve metin boyutu veya öğe sayısı için belirlenmiş bir sınır yoktur.

Belge güncellemeleri (ekleme, düzenleme, silme) Atomicity'yi takip eder, yani bunlar tamamen kaydedilir veya hiç kaydedilmez. Veritabanında kısmen kaydedilmiş veya düzenlenmiş belgeler olmayacaktır.

Json Belge Yapısı

{
   "field" : "value",
   "field" : "value",
   "field" : "value",
}

ACID Özellikleri

CouchDB, özelliklerinden biri olarak ACID özelliklerini içerir.

Tutarlılık - CouchDB'deki veriler bir kez işlendiğinde, bu veriler değiştirilmeyecek veya üzerine yazılmayacaktır. Böylece CouchDB, veritabanı dosyasının her zaman tutarlı bir durumda olmasını sağlar.

Çok Versiyonlu Eş Zamanlılık Kontrolü (MVCC) modeli, CouchDB okumaları tarafından kullanılır, çünkü müşteri, okuma işleminin başından sonuna kadar veritabanının tutarlı bir anlık görüntüsünü görecektir.

Bir belge her güncellendiğinde, CouchDB verileri diske boşaltır ve güncellenmiş veritabanı başlığı, dosyanın ilk 4k'sini oluşturmak için iki ardışık ve aynı parçaya yazılır ve ardından eşzamanlı olarak diske atılır. Yıkama sırasındaki kısmi güncellemeler iptal edilecektir.

Başlık işlenirken başarısızlık meydana gelirse, önceki aynı başlıkların kalan bir kopyası kalır ve önceden kaydedilmiş tüm verilerin tutarlılığını sağlar. Başlık alanı dışında, bir çarpışma veya elektrik kesintisinden sonra tutarlılık kontrolleri veya düzeltmeler asla gerekli değildir.

Sıkıştırma

Veritabanı dosyasındaki alan belirli bir derecenin üzerinde boşa harcandığında, tüm aktif veriler yeni bir dosyaya kopyalanacaktır (klonlanacaktır). Kopyalama işlemi tamamen tamamlandığında, eski dosya silinecektir. Bütün bunlar sıkıştırma işlemi ile yapılır. Veri tabanı, sıkıştırma sırasında çevrimiçi kalır ve tüm güncellemeler ve okumaların başarıyla tamamlanmasına izin verilir.

Görüntüleme

CouchDB'deki veriler, bağımsız örtük yapılarla esnek olan yarı yapılandırılmış belgelerde saklanır, ancak veri depolama ve paylaşımı için basit bir belge modelidir. Verilerimizi birçok farklı şekilde görmek istiyorsak, tablolara ayrıştırılmamış verileri filtrelemek, düzenlemek ve raporlamak için bir yönteme ihtiyacımız var.

Bu sorunu çözmek için CouchDB bir görünüm modeli sağlar. Görünümler, bir veritabanındaki belgeleri toplama ve raporlama yöntemidir ve veritabanı belgelerini toplamak, birleştirmek ve raporlamak için isteğe bağlı olarak oluşturulur. Görünümler dinamik olarak oluşturulduğundan ve temel belgeyi etkilemediğinden, aynı verilerin istediğiniz kadar farklı görünüm temsillerine sahip olabilirsiniz.

Tarih

  • CouchDB, Erlang programlama dilinde yazılmıştır.
  • 2005 yılında Damien Katz tarafından başlatıldı.
  • CouchDB, 2008'de bir Apache projesi oldu.

CouchDB'nin güncel sürümü 1.61'dir.

Bu bölüm size CouchDB'yi Windows ve Linux sistemlerine nasıl kuracağınızı öğretir.

Windows'ta CouchDB Kurulumu

CouchDB'yi indirin

CouchDB için resmi web sitesi https://couchdb.apache.org. Verilen bağlantıya tıklarsanız, aşağıda gösterildiği gibi CouchDB resmi web sitesinin ana sayfasına ulaşabilirsiniz.

İndirme düğmesine tıklarsanız, bu, CouchDB'nin çeşitli formatlarda indirme bağlantılarının sağlandığı bir sayfaya götürür. Aşağıdaki anlık görüntü aynı şeyi göstermektedir.

Windows sistemleri için indirme bağlantısını seçin ve indirme işleminizi başlatmak için sağlanan aynalardan birini seçin.

CouchDB'yi yükleme

CouchDB, sisteminize adlı kurulum dosyası biçiminde indirilecektir. setup-couchdb-1.6.1_R16B02.exe. Kurulum dosyasını çalıştırın ve kuruluma devam edin.

Kurulumdan sonra, aşağıdakileri ziyaret ederek CouchDB'nin yerleşik web arayüzünü açın. link: http://127.0.0.1:5984/. Her şey yolunda giderse, bu size aşağıdaki çıktıya sahip bir web sayfası verecektir.

{
   "couchdb":"Welcome","uuid":"c8d48ac61bb497f4692b346e0f400d60",
   "version":"1.6.1",
   "vendor":{
      "version":"1.6.1","name":"The Apache Software Foundation"
   }
}

Aşağıdaki url'yi kullanarak CouchDB web arayüzü ile etkileşim kurabilirsiniz -

http://127.0.0.1:5984/_utils/

Bu size CouchDB'nin web arayüzü olan Futon'un indeks sayfasını gösterir.

CouchDB'yi Linux Sistemlerine Kurmak

Linux aromalı sistemlerin çoğu için dahili olarak CouchDB sağlarlar. Bu CouchDB'yi kurmak için talimatları izleyin.

Ubuntu ve Debian'da şunları kullanabilirsiniz -

sudo aptitude install couchdb

Gentoo Linux'ta bir CouchDB ebuild mevcuttur -

sudo emerge couchdb

Linux sisteminizde CouchDB yoksa, CouchDB ve bağımlılıklarını kurmak için sonraki bölümü takip edin.

CouchDB Bağımlılıklarını Yükleme

Sisteminizde CouchDB'yi almak için kurulacak bağımlılıkların listesi aşağıdadır−

  • Erlang OTP
  • ICU
  • OpenSSL
  • Mozilla SpiderMonkey
  • GNU Yap
  • GNU Derleyici Koleksiyonu
  • libcurl
  • help2man
  • Docs için Python
  • Python Sfenks

Bu bağımlılıkları kurmak için, terminale aşağıdaki komutları yazın. Burada Centos 6.5 kullanıyoruz ve aşağıdaki komutlar Centos 6.5 uyumlu gerekli yazılımları kuracaktır.

$sudo yum install autoconf
$sudo yum install autoconf-archive
$sudo yum install automake
$sudo yum install curl-devel
$sudo yum install erlang-asn1
$sudo yum install erlang-erts
$sudo yum install erlang-eunit
$sudo yum install erlang-os_mon
$sudo yum install erlang-xmerl
$sudo yum install help2man
$sudo yum install js-devel
$sudo yum install libicu-devel
$sudo yum install libtool
$sudo yum install perl-Test-Harness

Note −Tüm bu komutlar için sudo kullanmanız gerekir. Aşağıdaki prosedür normal bir kullanıcıyı bir sudoer'a dönüştürür.

  • Yönetici kullanıcıda kök olarak oturum açın

  • Açık sudo aşağıdaki komutu kullanarak dosya -

visudo
  • Ardından, mevcut kullanıcınıza sudoer ayrıcalıkları vermek için aşağıda gösterildiği gibi düzenleyin -
Hadoop All=(All) All , and press esc : x to write the changes to the file.

Sisteminizdeki tüm bağımlılıkları indirdikten sonra, verilen talimatları izleyerek CouchDB'yi indirin.

CouchDB'yi indirme

Apache yazılım kuruluşu, CouchDB için .tar dosyasının tamamını sağlamaz, bu nedenle onu kaynaktan yüklemeniz gerekir.

CouchDB'yi kurmak için yeni bir dizin oluşturun, bu tür oluşturulmuş dizine göz atın ve aşağıdaki komutları uygulayarak CouchDB kaynağını indirin -

$ cd
$ mkdir CouchDB
$ cd CouchDB/
$ wget
http://www.google.com/url?q=http%3A%2F%2Fwww.apache.org%2Fdist%2Fcouchdb%2Fsource%2F1.6.1%2Fapache-couchdb-1.6.1.tar.gz

Bu, CouchDB kaynak dosyasını sisteminize indirecektir. Şimdi fermuarınıapache-couchdb-1.6.1.tar.gz Aşağıda gösterildiği gibi.

$ tar zxvf apache-couchdb-1.6.1.tar.gz

CouchDB'yi Yapılandırma

CouchDB'yi yapılandırmak için aşağıdakileri yapın -

  • CouchDB'nin ana klasörüne gidin.
  • Süper kullanıcı olarak giriş yapın.
  • ./Configure komut istemini kullanarak aşağıda gösterildiği gibi yapılandırın -
$ cd apache-couchdb-1.6.1
$ su
Password:
# ./configure --with-erlang=/usr/lib64/erlang/usr/include/

Size aşağıda gösterilene benzer aşağıdaki çıktıyı verir ve sonuç satırında - You have configured Apache CouchDB, time to relax.

# ./configure --with-erlang=/usr/lib64/erlang/usr/include/

checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
checking for a thread-safe mkdir -p... /bin/mkdir -p
checking for gawk... gawk
checking whether make sets $(MAKE)... yes
checking how to create a ustar tar archive... gnutar
………………………………………………………..
……………………….
config.status: creating var/Makefile
config.status: creating config.h
config.status: config.h is unchanged
config.status: creating src/snappy/google-snappy/config.h
config.status: src/snappy/google-snappy/config.h is unchanged
config.status: executing depfiles commands
config.status: executing libtool commands

You have configured Apache CouchDB, time to relax.

Run `make && sudo make install' to install.

CouchDB'yi yükleme

Şimdi CouchDB'yi sisteminize kurmak için aşağıdaki komutu yazın.

# make && sudo make install

CouchDB'yi sisteminize bir sonuç satırı ile kurar - You have installed Apache CouchDB, time to relax.

CouchDB'yi başlatma

CouchDB'yi başlatmak için CouchDB ana klasörüne gidin ve aşağıdaki komutu kullanın -

$ cd apache-couchdb-1.6.1
$ cd etc
$ couchdb start

Aşağıdaki çıktıyı vererek CouchDB'yi başlatır: -

Apache CouchDB 1.6.1 (LogLevel=info) is starting.
Apache CouchDB has started. Time to relax.
[info] [lt;0.31.0gt;] Apache CouchDB has started on http://127.0.0.1:5984/
[info] [lt;0.112.0gt;] 127.0.0.1 - - GET / 200
[info] [lt;0.112.0gt;] 127.0.0.1 - - GET /favicon.ico 200

Doğrulama

CouchDB bir web arayüzü olduğundan, aşağıdaki ana sayfa url'sini tarayıcıya yazmayı deneyin.

http://127.0.0.1:5984/

Aşağıdaki çıktıyı üretir -

{
   "couchdb":"Welcome",
   "uuid":"8f0d59acd0e179f5e9f0075fa1f5e804",
   "version":"1.6.1",
   "vendor":{
      "name":"The Apache Software Foundation",
      "version":"1.6.1"
   }
}

cURL Yardımcı Programı

cURL yardımcı programı, CouchDB ile iletişim kurmanın bir yoludur.

Desteklenen protokollerden (HTTP, HTTPS, FTP, FTPS, TFTP, DICT, TELNET, LDAP veya FILE) birini kullanarak verileri bir sunucudan veya bir sunucudan aktarmak için kullanılan bir araçtır. Komut, kullanıcı etkileşimi olmadan çalışmak üzere tasarlanmıştır. cURL, proxy desteği, kullanıcı kimlik doğrulaması, ftp yüklemesi, HTTP gönderisi, SSL (https :) bağlantıları, tanımlama bilgileri, dosya aktarımı devam ettirme ve daha fazlası gibi bir dizi yararlı numara sunar.

CURL yardımcı programı UNIX, Linux, Mac OS X ve Windows gibi işletim sistemlerinde mevcuttur. Kullanıcının komut satırından hemen HTTP protokolüne erişebildiği bir komut satırı yardımcı programıdır. Bu bölüm size cURL yardımcı programını nasıl kullanacağınızı öğretir.

CURL Yardımcı Programını Kullanma

CURL yardımcı programını kullanarak herhangi bir web sitesine, aşağıda gösterildiği gibi cURL yazıp ardından web sitesi adresini yazarak erişebilirsiniz -

curl www.tutorialspoint.com/

Varsayılan olarak, cURL yardımcı programı istenen sayfanın kaynak kodunu döndürür. Bu kodu terminal penceresinde görüntüler.

cURL Yardımcı Programı Seçenekleri

cURL yardımcı programı, çalışmak için çeşitli seçenekler sunar ve bunları cURL yardımcı programı yardımında görebilirsiniz.

Aşağıdaki kod, cURL yardımının bir bölümünü gösterir.

$ curl --help
Usage: curl [options...] <url>
Options: (H) means HTTP/HTTPS only, (F) means FTP only
      --anyauth Pick "any" authentication method (H)
   -a/--append Append to target file when uploading (F/SFTP)
      --basic Use HTTP Basic Authentication (H)
      --cacert <file> CA certificate to verify peer against (SSL)
-d/--data <data> HTTP POST data (H)
      --data-ascii <data> HTTP POST ASCII data (H)
      --data-binary <data> HTTP POST binary data (H)
      --data-urlencode <name=data/name@filename> HTTP POST data
urlencoded (H)
      --delegation STRING GSS-API delegation permission
      --digest Use HTTP Digest Authentication (H)
      --disable-eprt Inhibit using EPRT or LPRT (F)
      --disable-epsv Inhibit using EPSV (F)

   -F/--form <name=content> Specify HTTP multipart POST data (H)
      --form-string <name=string> Specify HTTP multipart POST data (H)
      --ftp-account <data> Account data to send when requested by server
(F)
      --ftp-alternative-to-user <cmd> String to replace "USER [name]" (F)
      --ftp-create-dirs Create the remote dirs if not present (F)
      --ftp-method [multi cwd/no cwd/single cwd] Control CWD usage (F)
      --ftp-pasv Use PASV/EPSV instead of PORT (F)

   -G/--get Send the -d data with a HTTP GET (H)

   -H/--header <line> Custom header to pass to server (H)
   -I/--head Show document info only
   -h/--help This help text
      --hostpubmd5 <md5> Hex encoded MD5 string of the host public key.
(SSH)
   -0/--http1.0 Use HTTP 1.0 (H)
      --ignore-content-length Ignore the HTTP Content-Length header
   -i/--include Include protocol headers in the output (H/F)

   -M/--manual Display the full manual

   -o/--output <file> Write output to <file> instead of stdout
      --pass <pass> Pass phrase for the private key (SSL/SSH)
      --post301 Do not switch to GET after following a 301
redirect (H)
      --post302 Do not switch to GET after following a 302
redirect (H)
   -O/--remote-name Write output to a file named as the remote file
      --remote-name-all Use the remote file name for all URLs
   -R/--remote-time Set the remote file's time on the local output
   -X/--request <command> Specify request command to use
      --retry <num> Retry request <num> times if transient problems
occur
      --retry-delay <seconds> When retrying, wait this many seconds
between each
      --retry-max-time <seconds> Retry only within this period
   -T/--upload-file <file> Transfer <file> to remote site
      --url <URL> Set URL to work with
   -B/--use-ascii Use ASCII/text transfer

CouchDB ile iletişim kurarken, cURL yardımcı programının belirli seçenekleri yoğun bir şekilde kullanıldı. Aşağıda, CouchDB tarafından kullanılanlar da dahil olmak üzere cURL yardımcı programının bazı önemli seçeneklerinin kısa açıklamaları verilmiştir.

-X bayrağı

(HTTP) HTTP sunucusuyla iletişim kurulurken kullanılan özel bir istek yöntemini belirtir. Aksi halde kullanılan yöntemin yerine belirtilen istek kullanılır (varsayılan olarak GET'dir). Ayrıntılar ve açıklamalar için HTTP 1.1 spesifikasyonunu okuyun.

(FTP) ftp ile dosya listeleri oluştururken LIST yerine kullanılacak özel bir FTP komutu belirtir.

-H

(HTTP) Bir web sayfası alınırken ekstra başlık kullanılır. CURL'nin kullanacağı dahili başlıklardan biriyle aynı ada sahip özel bir başlık eklerseniz, dahili başlık yerine harici olarak ayarlanmış başlığınızın kullanılacağını unutmayın. Bu, cURL'nin normalde yapacağından daha zor işler yapmanızı sağlar. Ne yaptığınızı tam olarak bilmeden dahili olarak ayarlanmış başlıkları değiştirmemelisiniz. Dahili bir başlığı, kolonun sağ tarafındaki içeriği olmayan bir başlık ile değiştirmek, bu başlığın görünmesini engelleyecektir.

cURL, eklediğiniz / değiştirdiğiniz her başlığın doğru satır sonu işaretiyle gönderilmesini sağlar. Bunu başlık içeriğinin bir parçası olarak eklememelisiniz, düzensiz şeylere satırsonu veya satır başı eklemelisiniz.

Ayrıca -A / - user-agent ve -e / - referer seçeneklerine bakın.

Bu seçenek, birden çok başlık eklemek / değiştirmek / kaldırmak için birden çok kez kullanılabilir.

-d bayrağı

Bu cURL bayrağını kullanarak, sunucuya HTTP POST isteği ile birlikte, kullanıcı tarafından formda doldurulmuş ve gönderilmiş gibi veri gönderebilirsiniz.

Example

Bir web sitesi olduğunu ve aşağıda gösterildiği gibi -d cURL yardımcı programını kullanarak web sitesine giriş yapmak veya bazı verileri göndermek istediğinizi varsayalım.

curl -X PUT http://mywebsite.com/login.html -d userid=001 -d password=tutorialspoint

Şuna benzeyen bir gönderi yığını gönderir "userid=001&password=tutorialspoint". Aynı şekilde -d işaretini kullanarak da belgeler (JSON) gönderebilirsiniz.

-o bayrak

Bu bayrağı kullanarak cURL, isteğin çıktısını bir dosyaya yazar.

Example

Aşağıdaki örnek, -o cURL yardımcı programının bayrağı.

$ curl -o example.html www.tutorialspoint.com/index.htm 
% Total % Received % Xferd Average Speed Time Time Time Current 
      Dload Upload Total Spent Left Speed
100 81193 0 81193 0 0 48168 0 --:--:-- 0:00:01 --:--:--
58077

Bu, tutorialspoint.com ana sayfasının kaynak kodunu alır, example.com adlı bir dosya oluşturur ve çıktıyı example.html adlı dosyaya kaydeder.

Aşağıdakinin anlık görüntüsü example.html.

Bu bayrak benzerdir –o, bu bayrakla tek fark, istenen url ile aynı isimde yeni bir dosya oluşturulmuş ve istenen url'nin kaynak kodu ona kopyalanacaktır.

Example

Aşağıdaki örnek, -O cURL yardımcı programının bayrağı.

$ curl -O www.tutorialspoint.com/index.htm
% Total % Received % Xferd Average Speed Time Time Time Current
      Dload Upload Total Spent Left
Speed
100 81285 0 81285 0 0 49794 0 --:--:-- 0:00:01 --:--:--
60077

İndex.htm adıyla yeni bir dosya oluşturur ve tutorialspoint.com'un indeks sayfasının kaynak kodunu içine kaydeder.

Merhaba CouchDB

Kurulu CouchDB örneğine bir GET isteği göndererek CouchDB'nin ana sayfasına erişebilirsiniz. Öncelikle, CouchDB'yi Linux ortamınıza kurduğunuzdan ve başarıyla çalıştığından emin olun ve ardından CouchDB örneğine bir alma isteği göndermek için aşağıdaki sözdizimini kullanın.

curl http://127.0.0.1:5984/

Bu size, aşağıda gösterildiği gibi, CouchDB'nin sürüm numarası, satıcının adı ve yazılım sürümü gibi ayrıntıları belirttiği bir JSON belgesi verir.

$ curl http://127.0.0.1:5984/
{
   "couchdb" : "Welcome",
   "uuid" : "8f0d59acd0e179f5e9f0075fa1f5e804",
   "version" : "1.6.1",
   "vendor" : {
      "name":"The Apache Software Foundation",
      "version":"1.6.1"
   }
}

Tüm Veritabanlarının Listesi

Dizeyle birlikte bir alma isteği göndererek oluşturulan tüm veritabanlarının listesini alabilirsiniz. "_all_dbs string ". CouchDB'deki tüm veritabanlarının listesini almak için sözdizimi aşağıdadır.

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

Aşağıda gösterildiği gibi CouchDB'deki tüm veritabanlarının listesini verir.

$ curl -X GET http://127.0.0.1:5984/_all_dbs
[ "_replicator" , "_users" ]

Veritabanı Oluşturmak

Aşağıdaki sözdizimini kullanarak PUT başlığı ile cURL kullanarak CouchDB'de bir veritabanı oluşturabilirsiniz -

$ curl -X PUT http://127.0.0.1:5984/database_name

Misal

Örnek olarak, yukarıda verilen sözdizimini kullanarak isimli bir veritabanı oluşturun. my_database Aşağıda gösterildiği gibi.

$ curl -X PUT http://127.0.0.1:5984/my_database
{"ok":true}

Doğrulama

Aşağıda gösterildiği gibi tüm veritabanlarını listeleyerek veritabanının oluşturulup oluşturulmadığını doğrulayın. Burada yeni oluşturulan veritabanının adını görebilirsiniz,"my_database" listede

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

[ "_replicator " , "_users" , "my_database" ]

Veritabanı Bilgilerini Alma

Veritabanı adı ile birlikte get isteğini kullanarak veritabanı hakkında bilgi alabilirsiniz. Veritabanı bilgilerini almak için sözdizimi aşağıdadır.

Misal

Örnek olarak isimli veritabanının bilgilerini alalım. my_databaseAşağıda gösterildiği gibi. Burada veritabanınız hakkındaki bilgileri yanıt olarak alabilirsiniz.

$ curl -X GET http://127.0.0.1:5984/my_database

{
   "db_name" : "my_database",
   "doc_count" : 0,
   "doc_del_count" : 0,
   "update_seq" : 0,
   "purge_seq" : 0,
   "compact_running" : false,
   "disk_size" : 79,
   "data_size" : 0,
   "instance_start_time" : "1423628520835029",
   "disk_format_version" : 6,
   "committed_update_seq" : 0
 }

şilte

Futon, CouchDB'nin yerleşik, web tabanlı yönetim arayüzüdür. CouchDB ile etkileşime girebileceğiniz basit bir grafik arayüz sağlar. Naif bir arayüzdür ve tüm CouchDB özelliklerine tam erişim sağlar. Bu özelliklerin listesi aşağıdadır -

Databases −
  • Veritabanları oluşturur.
  • Veritabanlarını yok eder.
Documents −
  • Belgeler oluşturur.
  • Belgeleri günceller.
  • Belgeleri düzenler.
  • Belgeleri siler.

Futon Başlangıç

CouchDB'nin çalıştığından emin olun ve ardından aşağıdaki url'yi tarayıcıda açın -

http://127.0.0.1:5984/_utils/

Bu url'yi açarsanız, Futon ana sayfasını aşağıda gösterildiği gibi görüntüler -

  • Bu sayfanın sol tarafında CouchDB'nin tüm güncel veri tabanlarının listesini görebilirsiniz. Bu resimde, adında bir veritabanımız varmy_database, sistem tanımlı veritabanları ile birlikte _replicator ve _user.

  • Sağ tarafta aşağıdakileri görebilirsiniz -

    • Tools - Bu bölümde bulabilirsiniz Configuration CouchDB'yi yapılandırmak için, Replicator replikasyonlar yapmak ve Status CouchDB'nin durumunu ve CouchDB'de yapılan son değişiklikleri doğrulamak için.

    • Documentation - Bu bölüm, CouchDB'nin son sürümü için eksiksiz dokümantasyonu içerir.

    • Diagnostics - Bunun altında CouchDB'nin kurulumunu doğrulayabilirsiniz.

    • Recent Databases - Bunun altında, son eklenen veritabanlarının adlarını bulabilirsiniz.

HTTP istek başlıklarını kullanarak CouchDB ile iletişim kurabilirsiniz. Bu talepler sayesinde veri tabanından veri alabilir, veri tabanına belge şeklinde veri depolayabilir ve veri tabanında depolanan belgeleri görüntüleyebilir ve biçimlendirebiliriz.

HTTP İstek Formatları

Veri tabanı ile iletişim kurarken get, head, post, put, delete ve copy gibi farklı istek formatlarını kullanacağız. CouchDB'deki tüm işlemler için, girdi verileri ve çıktı veri yapıları JavaScript Nesne Gösterimi (JSON) nesnesi biçiminde olacaktır.

Aşağıda, CouchDB ile iletişim kurmak için kullanılan farklı HTTP Protokolü istek formatları verilmiştir.

  • GET- Bu format, belirli bir öğeyi almak için kullanılır. Farklı öğeler almak için belirli url kalıpları göndermeniz gerekir. Bu GET talebini kullanarak CouchDB'de, statik öğeleri, veritabanı belgelerini ve yapılandırmayı ve JSON belgeleri biçiminde (çoğu durumda) istatistiksel bilgileri alabiliriz.

  • HEAD - HEAD yöntemi, yanıtın gövdesi olmadan bir GET isteğinin HTTP başlığını almak için kullanılır.

  • POST- Gönderi isteği, verileri yüklemek için kullanılır. POST isteğini kullanan CouchDB'de değerleri ayarlayabilir, belgeleri yükleyebilir, belge değerlerini ayarlayabilir ve ayrıca belirli yönetim komutlarını başlatabilirsiniz.

  • PUT - PUT talebini kullanarak yeni nesneler, veritabanları, belgeler, görünümler ve tasarım belgeleri oluşturabilirsiniz.

  • DELETE - SİL isteğini kullanarak belgeleri, görünümleri ve tasarım belgelerini silebilirsiniz.

  • COPY - KOPYALAMA yöntemini kullanarak belgeleri ve nesneleri kopyalayabilirsiniz.

HTTP İstek Başlıkları

Doğru biçimi ve kodlamayı elde etmek için HTTP başlıkları sağlanmalıdır. CouchDB sunucusuna istek gönderirken, istek ile birlikte Http istek başlıklarını da gönderebilirsiniz. Aşağıda farklı Http istek başlıkları verilmiştir.

  • Content-type- Bu Başlık, istekle birlikte sunucuya sağladığımız verilerin içerik türünü belirtmek için kullanılır. Çoğunlukla istekle birlikte gönderdiğimiz içerik türü MIME türü veya JSON (application / json) olacaktır. İstek üzerine Content-type kullanılması şiddetle tavsiye edilir.

  • Accept- Bu başlık, sunucuyu, istemcinin anlayabileceği veri türleri listesini belirtmek için kullanılır, böylece sunucu bu veri türlerini kullanarak yanıtını gönderir. Genellikle burada, istemcinin kabul ettiği MIME veri türlerinin listesini iki nokta üst üste ile ayırarak gönderebilirsiniz.

    CouchDB'nin sorgularında Accept'in kullanılması gerekli olmasa da, döndürülen verilerin müşteri tarafından işlenebildiğinden emin olunması şiddetle tavsiye edilir.

Yanıt Başlıkları

Bunlar, sunucu tarafından gönderilen yanıtın başlıklarıdır. Bu başlıklar, sunucu tarafından yanıt olarak gönderilen içerik hakkında bilgi verir.

  • Content-type- Bu başlık, sunucu tarafından döndürülen verilerin MIME türünü belirtir. Çoğu istek için, döndürülen MIME türü metin / düzdür.

  • Cache-control- Bu başlık, istemciye, sunucu tarafından gönderilen bilgileri işlemesini önerir. CouchDB, çoğunlukla, mümkünse bilgilerin yeniden doğrulanması gerektiğini belirten zorunlu yeniden doğrulama işlemini döndürür.

  • Content-length - Bu başlık, sunucu tarafından gönderilen içeriğin uzunluğunu bayt cinsinden döndürür.

  • Etag - Bu başlık, bir belgenin veya bir görünümün revizyonunu göstermek için kullanılır.

Durum Kodları

Aşağıda, http başlığı tarafından gönderilen durum kodunun tablo şekli ve açıklaması yer almaktadır.

Sr.No. Durum Kodu ve Açıklama
1

200 − OK

Bu durum, bir istek başarıyla tamamlandığında verilecektir.

2

201 − Created

Bu durum, bir belge oluşturulduğunda verilecektir.

3

202 − Accepted

Bu durum, bir talep kabul edildiğinde verilecektir.

4

404 − Not Found

Bu durum, sunucu istenen içeriği bulamadığında verilecektir.

5

405 − Resource Not Allowed

Bu durum, kullanılan HTTP istek türü geçersiz olduğunda verilir.

6

409 − Conflict

Bu durum, herhangi bir güncelleme çakışması olduğunda verilir.

7

415 − Bad Content Type

Bu durum, istenen içerik türünün sunucu tarafından desteklenmediğini gösterdi.

8

500 − Internal Server Error

Bu durum, talepte gönderilen veriler geçersiz olduğunda verilir.

HTTP URL Yolları

Veritabanıyla doğrudan etkileşime girebileceğiniz belirli url yolları vardır. Bu tür url yollarının tablo biçimi aşağıdadır.

Sr.No. URL ve İşlem
1

PUT /db

Bu url, yeni bir veritabanı oluşturmak için kullanılır.

2

GET /db

Bu url, mevcut veritabanı hakkında bilgi almak için kullanılır.

3

PUT /db/document

Bu url, bir belge oluşturmak / mevcut bir belgeyi güncellemek için kullanılır.

4

GET /db/document

Bu url belgeyi almak için kullanılır.

5

DELETE /db/document

Bu url, belirtilen belgeyi belirtilen veritabanından silmek için kullanılır.

6

GET /db/_design/design-doc

Bu url, bir tasarım belgesinin tanımını almak için kullanılır.

7

GET /db/_design/designdoc/_view/view-name

Bu url, belirtilen veritabanından tasarım belgesinden görünüme, görünüm adına erişmek için kullanılır.

Veritabanı, belgelerinizin saklandığı CouchDB'deki en dış veri yapısıdır. Bu veritabanlarını CouchDB tarafından sağlanan cURL yardımcı programını ve ayrıca CouchDB'nin web arayüzü Futon'u kullanarak oluşturabilirsiniz.

CURL Yardımcı Programını Kullanarak Veritabanı Oluşturma

CouchDB'de cURL yardımcı programı aracılığıyla PUT yöntemini kullanarak sunucuya bir HTTP isteği göndererek bir veritabanı oluşturabilirsiniz. Aşağıda bir veritabanı oluşturmak için sözdizimi verilmiştir -

$ curl -X PUT http://127.0.0.1:5984/database name

Kullanma −Xkullanılacak HTTP özel istek yöntemini belirtebiliriz. Bu durumda PUT yöntemini kullanıyoruz. PUT işlemini / yöntemini kullandığımızda, url'nin içeriği HTTP isteği kullanarak oluşturduğumuz nesne adını belirtir. Burada bir veritabanı oluşturmak için url'deki put isteğini kullanarak veritabanının adını göndermeliyiz.

Misal

Adı olan bir veritabanı oluşturmak istiyorsanız, yukarıda verilen sözdizimini kullanın my_databaseaşağıdaki gibi oluşturabilirsiniz

curl -X PUT http://127.0.0.1:5984/my_database
{
   "ok":true
}

Yanıt olarak sunucu size içeriği olan bir JSON belgesi döndürür “ok” - true operasyonun başarılı olduğunu belirten.

Doğrulama

Aşağıda gösterildiği gibi tüm veritabanlarını listeleyerek veritabanının oluşturulup oluşturulmadığını doğrulayın. Burada yeni oluşturulmuş bir veritabanının adını görebilirsiniz," my_database " listede.

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

[ "_replicator " , " _users " , " my_database " ]

Futon Kullanarak Veritabanı Oluşturmak

Bir veritabanı oluşturmak için http://127.0.0.1:5984/_utils/. Aşağıda gösterildiği gibi CouchDB'nin Genel Bakış / dizin sayfasını alacaksınız.

Bu sayfada, sol tarafta Veritabanı Oluştur seçenek düğmesi olan CouchDB'deki veritabanları listesini görebilirsiniz.

Şimdi veritabanı oluştur bağlantısına tıklayın. Bir açılır pencere görebilirsinizCreate New Databasesyeni veritabanı için veritabanı adını sormak. Belirtilen kriterlere göre herhangi bir isim seçin. Burada tutorials_point isimli başka bir veritabanı oluşturuyoruz. Aşağıdaki ekran görüntüsünde gösterildiği gibi oluştur düğmesine tıklayın.

CURL Yardımcı Programını Kullanarak Veritabanını Silme

CouchDB'deki bir veritabanını cURL aracıyla DELETE yöntemini kullanarak sunucuya istek göndererek silebilirsiniz. Aşağıda bir veritabanı oluşturmak için sözdizimi verilmiştir -

$ curl -X DELETE http://127.0.0.1:5984/database name

Kullanma −XHTTP sunucusu ile iletişim kurarken kullandığımız HTTP için özel bir istek yöntemi belirtebiliriz. Bu durumda DELETE yöntemini kullanıyoruz. URL'yi, silinecek veritabanını belirterek sunucuya gönderin.

Misal

CouchDB'de my_database2 adında bir veritabanı olduğunu varsayalım. Silmek istiyorsanız yukarıda verilen sözdizimini kullanarak, aşağıdaki gibi yapabilirsiniz -

$ curl -X DELETE http://127.0.0.1:5984/my_database2
{
   "ok" : true
}

Yanıt olarak, sunucu size içeriği olan bir JSON belgesi döndürür “ok” - true operasyonun başarılı olduğunu belirten.

Doğrulama

Aşağıda gösterildiği gibi tüm veritabanlarını listeleyerek veritabanının silinip silinmediğini doğrulayın. Burada silinen veritabanının adını görebilirsiniz,"my_database" listede yok.

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

[ "_replicator " , " _users " ]

Futon Kullanarak Veritabanını Silme

Bir veritabanını silmek için, http://127.0.0.1:5984/_utils/ Aşağıda gösterildiği gibi CouchDB'nin Genel Bakış / dizin sayfasını alacağınız url.

Burada kullanıcı tarafından oluşturulan üç veritabanını görebilirsiniz. Tutorials_point2 adlı veritabanını silelim. Bir veri tabanını silmek için, veri tabanları listesinden bir tane seçin ve üzerine tıklayın, bu veri tabanları üzerindeki çeşitli işlemleri görebileceğiniz seçili veri tabanının genel bakış sayfasına götürür. Aşağıdaki ekran görüntüsü aynı şeyi göstermektedir -

Aralarında bulabilirsin Delete Databaseseçeneği. Üzerine tıkladığınızda, emin olup olmadığınızı soran bir açılır pencere göreceksiniz! Seçilen veritabanını silmek için sil üzerine tıklayın.

Belgeler, CouchDB'nin merkezi veri yapısıdır. Veritabanının içeriği tablolar yerine Belgeler şeklinde saklanacaktır. Bu dokümanları CouchDB ve Futon tarafından sağlanan cURL yardımcı programını kullanarak oluşturabilirsiniz. Bu bölüm, bir veritabanında belge oluşturmanın yollarını kapsar.

CouchDB'deki her belgenin benzersiz bir kimliği vardır. Bir dize biçiminde olması gereken kendi kimliğinizi seçebilirsiniz. Genellikle, kopya oluşturma şansı en az olan rastgele sayılar olan UUID (Evrensel Benzersiz Tanımlayıcı) kullanılır. Çarpışmaları önlemek için bunlar tercih edilir.

CURL Yardımcı Programını kullanarak bir Belge Oluşturma

CURL yardımcı programı aracılığıyla PUT yöntemini kullanarak sunucuya bir HTTP isteği göndererek CouchDB'de bir belge oluşturabilirsiniz. Bir belge oluşturmak için sözdizimi aşağıdadır.

$ curl -X PUT http://127.0.0.1:5984/database name/"id" -d ' { document} '

Kullanma −XHTTP sunucusu ile iletişim kurarken kullandığımız HTTP için özel bir istek yöntemi belirtebiliriz. Bu durumda PUT yöntemini kullanıyoruz. PUT yöntemini kullandığımızda, url'nin içeriği HTTP isteğini kullanarak oluşturduğumuz nesne adını belirtir. Burada aşağıdakileri göndermeliyiz -

  • Belgeyi içinde oluşturduğumuz veritabanı adının adı.

  • Belge kimliği.

  • Belgenin verileri. −dseçeneği, verileri / belgeyi HTTP isteği yoluyla göndermek için kullanılır. Bir belge yazarken, Alan-Değer çiftlerinizi iki nokta üst üste ile ayrılmış olarak, aşağıda gösterildiği gibi çiçek parantezleri içine girin -

{
   Name : Raju
   age : 23
   Designation : Designer
}

Misal

Kimlikli bir belge oluşturmak istiyorsanız yukarıda verilen sözdizimini kullanın 001 isimli bir veritabanında my_database, aşağıda gösterildiği gibi oluşturabilirsiniz.

$ curl -X PUT http://127.0.0.1:5984/my_database/"001" -d
'{ " Name " : " Raju " , " age " :" 23 " , " Designation " : " Designer " }'

{"ok":true,"id":"001","rev":"1-1c2fae390fa5475d9b809301bbf3f25e"}

CouchDB'nin bu isteğe cevabı üç alan içeriyor -

  • "ok", operasyonun başarılı olduğunu belirten.

  • "id", belgenin kimliğini saklayan ve

  • "rev",bu revizyon kimliğini gösterir. Bir belgeyi her revize ettiğinizde (güncellediğinizde veya değiştirdiğinizde)_revdeğer CouchDB tarafından üretilecektir. Bir belgeyi güncellemek veya silmek isterseniz, CouchDB sizden şunları eklemenizi bekler:_revdeğiştirmek istediğiniz revizyon alanı. CouchDB değişikliği kabul ettiğinde yeni bir revizyon numarası oluşturacaktır. Bu mekanizma eşzamanlılık kontrolü sağlar.

Doğrulama

Oluşturulan belgeyi görüntülemek istiyorsanız, aşağıda gösterildiği gibi belgeyi kullanarak alabilirsiniz.

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   "_id": "001",
   "_rev": "1-3fcc78daac7a90803f0a5e383f4f1e1e",
   "Name": "Raju",
   "age": 23,
   "Designation": "Designer"
}

Futon Kullanarak Belge Oluşturmak

Bir belge oluşturmak için http://127.0.0.1:5984/_utils/ url'yi aşağıda gösterildiği gibi CouchDB'nin Genel Bakış / dizin sayfasını almak için kullanın.

Belgeyi oluşturmak istediğiniz veritabanını seçin. Veritabanının Genel Bakış sayfasını açın ve seçinNew Document seçeneği aşağıda gösterildiği gibi.

Seçtiğinizde New Documentseçeneği, CouchDB yeni bir veritabanı belgesi oluşturur ve ona yeni bir kimlik atar. İd'nin değerini düzenleyebilir ve bir dizi biçiminde kendi değerinizi atayabilirsiniz. Aşağıdaki çizimde 001 kimliğine sahip yeni bir belge oluşturduk.

Bu sayfada üç seçeneği gözlemleyebilirsiniz - Belgeyi Kaydet, Alan Ekle ve Eki Yükle.

Belgeye Alan Ekle

Belgeye alan eklemek için tıklayın Add Fieldseçeneği. Bir veritabanı oluşturduktan sonra, bu seçeneği kullanarak ona bir alan ekleyebilirsiniz. Üzerine tıkladığınızda size bir çift metin kutusu, yaniField, value.Bu değerleri üzerlerine tıklayarak düzenleyebilirsiniz. Bu değerleri düzenleyin ve istediğiniz Alan-Değer çiftini yazın. Bu değerleri kaydetmek için yeşil düğmeye tıklayın.

Aşağıdaki çizimde, çalışanın adı, yaşı ve adı olmak üzere üç alan oluşturduk.

Belgeyi Kaydet

Bu seçeneğe tıklayarak belgede yapılan değişiklikleri kaydedebilirsiniz. Kaydettikten sonra yeni bir kimlik_rev aşağıda gösterildiği gibi oluşturulacaktır.

Belgeleri cURL kullanarak güncelleme

CouchDB'deki bir belgeyi, cURL yardımcı programı aracılığıyla PUT yöntemini kullanarak sunucuya bir HTTP isteği göndererek güncelleyebilirsiniz. Bir belgeyi güncellemek için sözdizimi aşağıdadır.

curl -X PUT http://127.0.0.1:5984/database_name/document_id/ -d '{ "field" : "value", "_rev" : "revision id" }'

Misal

My_database adlı veritabanında 001 kimliğine sahip bir belge olduğunu varsayalım. Bunu aşağıda gösterildiği gibi silebilirsiniz.

Öncelikle güncellenecek belgenin revizyon kimliğini alın. Bulabilirsin_rev belgenin kendisi, bu nedenle belgeyi aşağıda gösterildiği gibi alın.

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   "_id" : "001",
   "_rev" : "2-04d8eac1680d237ca25b68b36b8899d3 " ,
   "age" : "23"
}

Belgeyi güncellemek için belgedeki _rev revizyon kimliğini kullanın. Burada yaşı 23'ten 24'e güncelliyoruz.

$ curl -X PUT http://127.0.0.1:5984/my_database/001/ -d
' { " age " : " 24 " , " _rev " : " 1-1c2fae390fa5475d9b809301bbf3f25e " } '

{ " ok " : true , " id " : " 001 " , " rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " }

Doğrulama

Belgeyi doğrulamak için, aşağıda gösterildiği gibi GET isteğini kullanarak belgeyi tekrar alın.

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   " _id " : " 001 ",
   " _rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " ,
   " age " : " 23 "
 }
Note

Bir belgeyi güncellerken dikkat edilmesi gereken bazı önemli noktalar aşağıdadır.

  • Veritabanı adını ve belge kimliğini içeren talepte gönderdiğimiz URL.

  • Mevcut bir belgeyi güncellemek, tüm belgeyi güncellemekle aynıdır. Mevcut bir belgeye alan ekleyemezsiniz. Aynı belge kimliğiyle yalnızca belgenin tamamen yeni bir sürümünü veritabanına yazabilirsiniz.

  • JSON talebinin bir parçası olarak revizyon numarasını sağlamamız gerekiyor.

  • Buna karşılık JSON, başarı mesajını, güncellenen belgenin kimliğini ve yeni revizyon bilgilerini içerir. Belgenin yeni sürümünü güncellemek istiyorsanız, bu son revizyon numarasını belirtmelisiniz.

Futon Kullanarak Belgelerin Güncellenmesi

Bir belgeyi silmek için http://127.0.0.1:5984/_utils/ url'yi aşağıda gösterildiği gibi CouchDB'nin Genel Bakış / dizin sayfasını almak için kullanın.

Güncellenecek belgenin mevcut olduğu veritabanını seçin ve tıklayın. Burada adlı veritabanındaki bir belgeyi güncelliyoruztutorials_point. Aşağıda gösterildiği gibi veritabanındaki belgelerin listesini alacaksınız.

Güncellemek istediğiniz bir belgeyi seçin ve üzerine tıklayın. Belgelerin içeriğini aşağıda gösterildiği gibi alacaksınız.

Burada, konumu Delhi'den Haydarabad'a güncellemek için metin kutusuna tıklayın, alanı düzenleyin ve aşağıda gösterildiği gibi değişiklikleri kaydetmek için yeşil düğmeye tıklayın.

CURL Yardımcı Programını kullanarak bir Belgeyi Silme

CouchDB'deki bir belgeyi cURL aracıyla DELETE yöntemini kullanarak sunucuya HTTP isteği göndererek silebilirsiniz. Bir belgeyi silmek için sözdizimi aşağıdadır.

curl -X DELETE http : // 127.0.0.1:5984 / database name/database id?_rev id

Kullanma −X,HTTP sunucusu ile iletişim kurarken kullandığımız HTTP için özel bir istek yöntemi belirtebiliriz. Bu durumda Delete yöntemini kullanıyoruz. Bir veritabanını silmek /database_name/database_id/yeterli değildir. Son revizyon kimliğini url üzerinden iletmelisiniz. Herhangi bir veri yapısının özniteliklerinden bahsetmek için"?" kullanıldı.

Misal

Veritabanında adlı bir belge olduğunu varsayalım my_database001 belge kimliğiyle. Bu belgeyi silmek için belgenin rev kimliğini almanız gerekir. Belge verilerini aşağıda gösterildiği gibi alın.

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   " _id " : " 001 ",
   " _rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " ,
   " age " : " 23 "
}

Şimdi silinecek belgenin revizyon kimliğini, belgenin kimliğini ve belgenin ait olduğu veritabanı adını aşağıda gösterildiği gibi belirtin -

$ curl -X DELETE http://127.0.0.1:5984/my_database/001?rev=1-
3fcc78daac7a90803f0a5e383f4f1e1e

{"ok":true,"id":"001","rev":"2-3a561d56de1ce3305d693bd15630bf96"}

Doğrulama

Belgenin silinip silinmediğini doğrulamak için, belgeyi kullanarak GETyöntem. Silinen bir dokümanı getirdiğiniz için, bu size aşağıda gösterildiği gibi bir hata mesajı verecektir -

$ curl -X GET http://127.0.0.1:5984/my_database/001
{"error":"not_found","reason":"deleted"}

Futon Kullanarak Bir Belgeyi Silme

Öncelikle veri tabanındaki belgeleri doğrulayın. Aşağıdaki, adlı veritabanının anlık görüntüsüdürtutorials_point.

Burada gözlemleyebilirsiniz, veritabanı üç belgeden oluşmaktadır. Herhangi bir belgeyi silmek için şunu söyleyin:003, aşağıdakileri yapın -

  • Belgeye tıkladığınızda, seçilen belgenin içeriğini alan-değer çiftleri şeklinde gösteren bir sayfa alacaksınız.

  • Bu sayfa ayrıca dört seçenek içerir: Save Document, Add Field, Upload Attachment, Delete Document.

  • Tıklamak Delete Document seçeneği.

  • Diyen bir iletişim kutusu alacaksınız "Are you sure you want to delete this document?" Belgeyi silmek için sil üzerine tıklayın.

CURL kullanarak Dosyaları Eklemek

E-posta gibi CouchDB'ye dosya ekleyebilirsiniz. Dosya, ad gibi meta verileri içerir ve MIME türünü ve ekin içerdiği bayt sayısını içerir. Bir belgeye dosya eklemek için sunucuya PUT isteği göndermeniz gerekir. Belgeye dosya eklemek için sözdizimi aşağıdadır -

$ curl -vX PUT http://127.0.0.1:5984/database_name/database_id
/filename?rev=document rev_id --data-binary @filename -H "Content-Type:
type of the content"

İsteğin aşağıda açıklanan çeşitli seçenekleri vardır.

  • --data-binary@ - Bu seçenek, cURL'ye bir dosyanın içeriğini HTTP istek gövdesine okumasını söyler.

  • -H - Bu seçenek, yükleyeceğimiz dosyanın içerik türünü belirtmek için kullanılır.

Misal

Adlı bir dosya ekleyelim boy.jpg, kimliğe sahip belgeye 001, adlı veritabanında my_databaseCouchDB'ye PUT isteği göndererek. Bundan önce, kimliğe sahip belgenin verilerini almanız gerekir.001 akımını almak için rev id aşağıda gösterildiği gibi.

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   "_id": "001",
   "_rev": "1-967a00dff5e02add41819138abb3284d"
}

Şimdi kullanarak _rev değeri, PUT isteğini aşağıda gösterildiği gibi CouchDB sunucusuna gönderin.

$ curl -vX PUT http://127.0.0.1:5984/my_database/001/boy.jpg?rev=1-
967a00dff5e02add41819138abb3284d --data-binary @boy.jpg -H "ContentType:
image/jpg"

Doğrulama

Ekin yüklenip yüklenmediğini doğrulamak için, belge içeriğini aşağıda gösterildiği gibi alın−

$ curl -X GET http://127.0.0.1:5984/my_database/001
{
   "_id": "001",
   "_rev": "2-4705a219cdcca7c72aac4f623f5c46a8",
   "_attachments": {
      "boy.jpg": {
         "content_type": "image/jpg",
         "revpos": 2,
         "digest": "md5-9Swz8jvmga5mfBIsmCxCtQ==",
         "length": 91408,
         "stub": true
      }
   }
}

Futon Kullanarak Dosya Eklemek

Eki Yükle

Bu seçeneği kullanarak dosya, görüntü veya belge gibi yeni bir eki veritabanına yükleyebilirsiniz. Bunu yapmak için,Upload Attachmentbuton. Yüklenecek dosyayı seçebileceğiniz bir iletişim kutusu görünecektir. Dosyayı seçin veUpload buton.

Yüklenen dosya _attachments alanı altında görüntülenecektir. Daha sonra üzerine tıklayarak dosyayı görebilirsiniz.