2014-11-24 15 views
6

DynamoDB (veya özellikle DynamoDB veri modelinin kavramları) için AWS Ruby SDK belgelerinin etrafına kafamı sarmış görünmüyorum. ÖzellikleRuby ile AWS DynamoDB içindeki öznitelikleri anlama

ben okuyordum: http://docs.aws.amazon.com/AWSRubySDK/latest/frames.html#!AWS/DynamoDB.html

Note: I have read through the Data Model documentation as well and it's still not sinking in; I'm hoping a proper example in Ruby with clear up my confusion

aşağıdaki kod parçacığını, ben "ITEM_ID" adlı bir primary_key vardır "my_books" adında bir tablo oluşturmak ve bir Kare tuşu (bir Hash var/Aralık bileşimi) ...

dyn = AWS::DynamoDB::Client::V20120810.new 
# => #<AWS::DynamoDB::Client::V20120810> 

dyn.create_table({ 
    :attribute_definitions => [ 
    { :attribute_name => "item_id", :attribute_type => "N" } 
    ], 
    :table_name => "my_books", 
    :key_schema => [ 
    { :attribute_name => "item_id", :key_type => "HASH" }, 
    ], 
    :provisioned_throughput => { 
    :read_capacity_units => 10, 
    :write_capacity_units => 10 
    } 
}) 
# => {:table_description=>{:attribute_definitions=>[{:attribute_name=>"item_id", :attribute_type=>"N"}], :table_name=>"my_books", :key_schema=>[{:attribute_name=>"item_id", :key_type=>"HASH"}], :table_status=>"ACTIVE", :creation_date_time=>2014-11-24 16:59:47 +0000, :provisioned_throughput=>{:number_of_decreases_today=>0, :read_capacity_units=>10, :write_capacity_units=>10}, :table_size_bytes=>0, :item_count=>0}} 

dyn.list_tables 
# => {:table_names=>["my_books"]} 

dyn.scan :table_name => "my_books" 
# => {:member=>[], :count=>0, :scanned_count=>0} 

Daha sonra tabloyu yeni bir öğe ile doldurmaya çalışıyorum. Anladığım kadarıyla ... Ben item_id sayısal değeri belirtmek gerekir (birincil anahtar olan) ve sonra ben tabloya ekliyorum yeni öğe/kayıt/belge için diğer özelliklerini belirleyebildiğinde olmasıdır

dyn.put_item(
    :table_name => "my_books", 
    :item => { 
    "item_id" => 1, 
    "item_title" => "My Book Title", 
    "item_released" => false 
    } 
) 

Ama bu geçen komut aşağıdaki hata verir: oldukça karma yapılmış olacak anlamıyorum rağmen Yani

expected hash value for value at key item_id of option item 

, bunu yaparken deneyin:

dyn.put_item(
    :table_name => "my_books", 
    :item => { 
    "item_id" => { "N" => 1 }, 
    "item_title" => "My Book Title", 
    "item_released" => false 
    } 
) 

Ancak bu, şu hatayı döndürür ...

expected string value for key N of value at key item_id of option item 

Farklı varyasyonlar denedim, ancak bunun nasıl çalıştığını anlayamıyorum?


DÜZENLEME/GÜNCELLEME: Uri Agassi önerdiği gibi - ben 1 den "1" değer değiştirdi. Ben neden emin değilim emin değilim bu tür bir sayı ve bir dize olarak tanımladım, ancak Tamam sadece kabul ve devam edelim.

+0

deneyin '... "ITEM_ID"=> { "N" => "1"}, ... '- hata mesajına göre bir dize değeri bekleniyor –

cevap

6

Son olarak, DynamoDB'nin veri modelini ve Ruby SDK'yı kullanmam için gerekenleri anladım. Aşağıda

umarım bir başkası yardımcı olacaktır benim kod örneği, ve ben burada tamamen fleshed örnek var: https://gist.github.com/Integralist/9f9f2215e001b15ac492#file-3-dynamodb-irb-session-rb

# https://github.com/BBC-News/alephant-harness can automate the below set-up when using Spurious 
# API Documentation http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Operations.html 
# Ruby SDK API Documentation http://docs.aws.amazon.com/AWSRubySDK/latest/frames.html#!AWS/DynamoDB/Client/V20120810.html 

require "aws-sdk" 
require "dotenv" 
require "spurious/ruby/awssdk/helper" 

Spurious::Ruby::Awssdk::Helper.configure 
# => <AWS::Core::Configuration> 

Dotenv.load(
    File.join(
    File.dirname(__FILE__), "config", "development", "env.yaml" 
) 
) 
# => {"AWS_REGION"=>"eu-west-1", "AWS_ACCESS_KEY_ID"=>"development_access", "AWS_SECRET_ACCESS_KEY"=>"development_secret", "DYNAMO_LU"=>"development_lookup", "DYNAMO_SQ"=>"development_sequence", "SQS_QUEUE"=>"development_queue", "S3_BUCKET"=>"development_bucket"} 

dyn = AWS::DynamoDB::Client.new :api_version => "2012-08-10" 
dyn = AWS::DynamoDB::Client::V20120810.new 
# => #<AWS::DynamoDB::Client::V20120810> 

dyn.create_table({ 
    # This section requires us to define our primary key 
    # Which will be called "item_id" and it must be a numerical value 
    :attribute_definitions => [ 
    { :attribute_name => "item_id", :attribute_type => "N" } 
    ], 
    :table_name => "my_books", 
    # The primary key will be a simple Hash key (not a Hash/Range which requires both key types to be provided) 
    # The attributes defined above must be included in the :key_schema Array 
    :key_schema => [ 
    { :attribute_name => "item_id", :key_type => "HASH" } 
    ], 
    :provisioned_throughput => { 
    :read_capacity_units => 10, 
    :write_capacity_units => 10 
    } 
}) 
# => {:table_description=>{:attribute_definitions=>[{:attribute_name=>"item_id", :attribute_type=>"N"}], :table_name=>"my_books", :key_schema=>[{:attribute_name=>"item_id", :key_type=>"HASH"}], :table_status=>"ACTIVE", :creation_date_time=>2014-11-24 16:59:47 +0000, :provisioned_throughput=>{:number_of_decreases_today=>0, :read_capacity_units=>10, :write_capacity_units=>10}, :table_size_bytes=>0, :item_count=>0}} 

dyn.list_tables 
# => {:table_names=>["my_books"]} 

dyn.scan :table_name => "my_books" 
# => {:member=>[], :count=>0, :scanned_count=>0} 

dyn.put_item(
    :table_name => "my_books", 
    :item => { 
    "item_id" => { "N" => "1" }, # oddly this needs to be a String and not a strict Integer? 
    "item_title" => { "S" => "My Book Title"}, 
    "item_released" => { "B" => "false" } 
    } 
) 
# Note: if you use an "item_id" that already exists, then the item will be updated. 
#  Unless you use the "expected" conditional feature 

dyn.put_item(
    :table_name => "my_books", 
    :item => { 
    "item_id" => { "N" => "1" }, # oddly this needs to be a String and not a strict Integer? 
    "item_title" => { "S" => "My Book Title"}, 
    "item_released" => { "B" => "false" } 
    }, 
    # The :expected key specifies the conditions of our "put" operation. 
    # If "item_id" isn't NULL (i.e. it exists) then our condition has failed. 
    # This means we only write the value when the key "item_id" hasn't been set. 
    :expected => { 
    "item_id" => { :comparison_operator => "NULL" } 
    } 
) 
# AWS::DynamoDB::Errors::ConditionalCheckFailedException: The conditional check failed 

dyn.scan :table_name => "my_books" 
# => {:member=>[{"item_id"=>{:n=>"1"}, "item_title"=>{:s=>"My Book Title"}, "item_released"=>{:b=>"false"}}], :count=>1, :scanned_count=>1} 

dyn.query :table_name => "my_books", :consistent_read => true, :key_conditions => { 
    "item_id" => { 
    :comparison_operator => "EQ", 
    :attribute_value_list => [{ "n" => "1" }] 
    }, 
    "item_title" => { 
    :comparison_operator => "EQ", 
    :attribute_value_list => [{ "s" => "My Book Title" }] 
    } 
} 
# => {:member=>[{"item_id"=>{:n=>"1"}, "item_title"=>{:s=>"My Book Title"}, "item_released"=>{:b=>"false"}}], :count=>1, :scanned_count=>1} 

dyn.query :table_name => "my_books", 
    :consistent_read => true, 
    :select => "SPECIFIC_ATTRIBUTES", 
    :attributes_to_get => ["item_title"], 
    :key_conditions => { 
    "item_id" => { 
    :comparison_operator => "EQ", 
    :attribute_value_list => [{ "n" => "1" }] 
    }, 
    "item_title" => { 
    :comparison_operator => "EQ", 
    :attribute_value_list => [{ "s" => "My Book Title" }] 
    } 
} 
# => {:member=>[{"item_title"=>{:s=>"My Book Title"}}], :count=>1, :scanned_count=>1} 

dyn.delete_item(
    :table_name => "my_books", 
    :key => { 
    "item_id" => { "n" => "1" } 
    } 
) 
# => {:member=>[], :count=>0, :scanned_count=>0} 
+0

Teşekkürler, günümü kurtardın – ebuprofen

+0

Teşekkürler @ebuprofen :-) – Integralist