一、创建表

 1 var AWS = require("aws-sdk");
2 AWS.config.update({
3 region: "us-west-2", //使用哪个区域的aws服务
4 endpoint: "http://localhost:8000" //dynamodb位置
5 });
6 var dynamodb = new AWS.DynamoDB();
7
8 var params = {
9 TableName: "Movies",//表名
10 KeySchema: [ //主键
11 {AttributeName: "year", KeyType: "HASH"}, //Partition key 分区键
12 {AttributeName: "title", KeyType: "RANGE"} //Sort key 排序键
13 ],
14 AttributeDefinitions: [//主键数据类型
15 {AttributeName: "year", AttributeType: "N"},//N Number
16 {AttributeName: "title", AttributeType: "S"} //S String
17 ],
18 ProvisionedThroughput: { //DynamoDB吞吐量配置
19 ReadCapacityUnits: 10,
20 WriteCapacityUnits: 10
21 }
22 };
23 dynamodb.createTable(params, function (err, data) {
24 if (err) {
25 console.error("Unable to create table. Error JSON:", JSON.stringify(err, null, 2));
26 } else {
27 console.log("Created table. Table description JSON:", JSON.stringify(data, null, 2));
28 }
29 });

二、增加项

 var docClient = new AWS.DynamoDB.DocumentClient();
var table = "Movies";
var year = 2015;
var title = "The Big New Movie";
var params = {
TableName: table,//要操作的表名
Item: {
"year": year,//主键-分区间
"title": title,//主键-排序键
"info": { //其他属性
"plot": "Nothing happens at all.", "rating": 0
}
}
};
console.log("Adding a new item...");
docClient.put(params, function (err, data) {
if (err) {
console.error("Unable to add item. Error JSON:", JSON.stringify(err, null, 2));
} else {
console.log("Added item:", JSON.stringify(data, null, 2));
}
});

三、获取项

 var docClient = new AWS.DynamoDB.DocumentClient()
var table = "Movies";//表名必须填
var year = 2015; //待查询的分区键
var title = "The Big New Movie";//待查询的排序键 如果表建立时设置为复合主键的话,分区键排序键必须都存在
var params = {TableName: table, Key: {"year": year, "title": title}};
docClient.get(params, function (err, data) {
if (err) {
console.error("Unable to read item. Error JSON:", JSON.stringify(err, null, 2));
} else {
console.log("GetItem succeeded:", JSON.stringify(data, null, 2));
}
});

四、更新项

 var table = "Movies";
var year = 2015;
var title = "The Big New Movie"; // Update the item, unconditionally,
var params = {
TableName: table, Key: {
"year": year,//分区键
"title": title//排序键 主键在update接口必须
}, UpdateExpression: "set info.rating = :r, info.plot=:p, info.actors=:a",//想要改变值的表达式
ExpressionAttributeValues: { //为想要改变的值赋值
":r": 5.5, ":p": "Everything happens all at once.", ":a": ["Larry", "Moe", "Curly"]
}, ReturnValues: "UPDATED_NEW"//返回更新值,即下中data
};
console.log("Updating the item...");
docClient.update(params, function (err, data) {
console.log(data);
if (err) {
console.error("Unable to update item. Error JSON:", JSON.stringify(err, null, 2));
} else {
console.log("UpdateItem succeeded:", JSON.stringify(data, null, 2));
}
});

五、删除项

 var table = "Movies";
var year = 2015;
var title = "The Big New Movie";
var params = {
TableName: table,//待删除操作的表
Key: {
"year": year,//分区键
"title": title//排序键
},
ExpressionAttributeNames:{"#u":"User"},
ConditionExpression: "#u = :val",//删除条件表达式
ExpressionAttributeValues: {
":val": 5.0 //条件值
}
};
console.log("Attempting a conditional delete...");
docClient.delete(params, function (err, data) {
if (err) {
console.error("Unable to delete item. Error JSON:", JSON.stringify(err, null, 2));
} else {
console.log("DeleteItem succeeded:", JSON.stringify(data, null, 2));
}
});

六、批量查询

 var params = {
RequestItems: {
"GsdSubDevices": {
Keys: [
{
"Mac": "haha"
},
{
"Mac": "111"
},
{
"Mac": "222"
}
]
}
}
};
console.log("requestArr===>" + JSON.stringify(requestArr));
docClient.batchGet(params, function (err, data) {
if (err) {
console.error("Unable to read item. Error JSON:", JSON.stringify(err, null, 2));
} else { }
});
 推荐操作数据库时使用以上操作,操作DynamoDB数据库有两种方式,另一种见DynamoBD常见操作(二),这种方式比较繁琐,不推荐使用

DynamoDB的基本操作(一)的更多相关文章

  1. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  2. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

  3. Android Notification 详解——基本操作

    Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...

  4. 三、Redis基本操作——List

    小喵的唠叨话:前面我们介绍了Redis的string的数据结构的原理和操作.当时我们提到Redis的键值对不仅仅是字符串.而这次我们就要介绍Redis的第二个数据结构了,List(链表).由于List ...

  5. 二、Redis基本操作——String(实战篇)

    小喵万万没想到,上一篇博客,居然已经被阅读600次了!!!让小喵感觉压力颇大.万一有写错的地方,岂不是会误导很多筒子们.所以,恳请大家,如果看到小喵的博客有什么不对的地方,请尽快指正!谢谢! 小喵的唠 ...

  6. 一、Redis基本操作——String(原理篇)

    小喵的唠叨话:最近京东图书大减价,小喵手痒了就买了本<Redis设计与实现>[1]来看看.这里权当小喵看书的笔记啦.这一系列的模式,主要是先介绍Redis的实现原理(可能很大一部分会直接照 ...

  7. Linq查询基本操作

    摘要:本文介绍Linq查询基本操作(查询关键字) - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 ...

  8. C++ map的基本操作和使用

    原文地址:http://blog.sina.com.cn/s/blog_61533c9b0100fa7w.html Map是c++的一个标准容器,她提供了很好一对一的关系,在一些程序中建立一个map可 ...

  9. python之最强王者(10)———文件(File)、输入输出的基本操作

    1. Python 文件I/O 本章只讲述所有基本的的I/O函数,更多函数请参考Python标准文档. 2.打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式. ...

随机推荐

  1. docker安装 2016-11-06 19:14 299人阅读 评论(31) 收藏

    Docker支持运行在以下CentOS版本: CentOS 7.X 安装在二进制兼容的EL7版本如 Scientific Linux也是可能成功的,但是Docker 没有测试过并且不官方支持. 此文带 ...

  2. Gym - 101962B_Color Changing Sofa

    题意:将一个沙发放到一个分成好几个色块(一个字母代表一种颜色)的房间里,要求沙发染成跟所在色块一样的颜色,沙发分成(0,1)两种,0可以染成一种颜色,1可以染成一种颜色(换句话说,沙发最多两种颜色), ...

  3. Java练习 SDUT-2499_数字

    数字 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 定义f(x) = {比x小,不可以被x整除并且不和x互质的数的个数 ...

  4. 【NS2】NS2在ubuntu下的安装

    Step1: 更新系统.在终端输入如下命令 sudo apt-get  update #更新源列表sudo apt-get upgrade #更新已经安装的包sudo apt-get dist-upg ...

  5. Java面向对象----Java面向对象(OOP)概念

    理解面向对象 关键:让每一个对象负责执行一组相关任务 面向过程:算法第一,数据第二 面向对象:数据第一,算法第一 特点: 万物皆对象 程序是一组对象彼此之间在发送消息 每个对象都有自己的内存占用,可以 ...

  6. C++类继承中的虚方法

    #include <bits/stdc++.h> using namespace std; class A { public: void Show() { cout << &q ...

  7. 2019-7-22-Roslyn-获得-sln-文件所在的文件夹

    title author date CreateTime categories Roslyn 获得 sln 文件所在的文件夹 lindexi 2019-07-22 08:57:14 +0800 201 ...

  8. HDU-1069_Monkey and Banana

    Monkey and Banana Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) P ...

  9. 14.libgdx的一些坑记录(持续更新)

    1. internal的文件路径 无法用list获取目录下文件     2.动态打包散图无法放入资源管理器,只能在资源加载器打包后的散图再合成打包,但都不如提前打包 3.资源加载器读入以texture ...

  10. oralce函数 next_day(d1[,c1])

    [功能]:返回日期d1在下周,星期几(参数c1)的日期 [参数]:d1日期型,c1为字符型(参数),c1默认为j(即当前日期) [参数表]:c1对应:星期一,星期二,星期三……星期日 [返回]:日期 ...