ets结合record的增删改查操作
来源:互联网 发布:java填空题 编辑:程序博客网 时间:2024/06/14 09:13
[erlang]ets结合record的增删改查操作
转载自:http://lajabs.net/2009/08/30/erlangets%E7%BB%93%E5%90%88record%E7%9A%84%E5%A2%9E%E5%88%A0%E6%94%B9%E6%9F%A5%E6%93%8D%E4%BD%9C/
record作为erlang的一种数据结构(特殊的Tuple,类似数组),通常用于函数量传递.
我们也可以选择ETS内存表作为存放record,Ets非常适合大量临时数据存储,最重要
的是ETS可以和record进行无逢结合.
%%在Eshell下声明record users
1> rd(users, {uid,website="t.qq.com/lajabs",name,time=time()}).
users
%%对ets建表,并创建以record元素uid作为索引键,以下的增删改查都将使用它
2> ets:new(users,[public,set,named_table,{keypos, #users.uid}]).
users
%%创建record,并对元素赋值
3> Users=#users{uid=101,name=lajabs}.
#users{uid = 101,website="t.qq.com/lajabs",name = lajabs,
time = {16,48,32}}
%%将创建好的record存入ets
4> ets:insert(users,Users).
true
%%创建第二个record
5> Users2=#users{uid=102,name=laja2}.
#users{uid = 102,website="t.qq.com/lajabs",name = laja2,
time = {16,49,16}}
%%把record users也存入ets,这时users表中有2笔记录
6> ets:insert(users,Users2).
true
%%尝试查询uid(索引键)为102的记录,成功返回record(之前定义的变量Users2),需要注意返回的是列表(带[])
7> ets:lookup(users,102).
[#users{uid = 102,website="t.qq.com/lajabs",name = laja2,
time = {16,49,16}}]
%%对ets更新record,将元素name改为'hello'
8> ets:update_element(users,102,{#users.name, hello}).
true
%%查看修改后的结果,发现已经更改成功
9> ets:lookup(users,102).
[#users{uid = 102,website="t.qq.com/lajabs",name = hello,
time = {16,49,16}}]
%%删除uid(索引键)为102的记录
10> ets:delete(users,102).
true
%%查看结果,已删除成功,返回的是空列表[]
11> ets:lookup(users,102).
[]
%%查询记录中的某个元素值可以用以下方式
12> ets:lookup_element(users,101,#users.name).
lajabs
Using ETS in Erlang Shell 坚强博客、
http://www.cnblogs.com/me-sa/archive/2012/04/01/using-ets-in-erlang-shell.html
[Erlang 0007] Erlang ETS Table 二三事
http://www.cnblogs.com/me-sa/archive/2011/08/11/erlang0007.html
http://www.erlang.org/doc/man/ets.html#type-match_pattern ets 帮助文档
- ets结合record的增删改查操作
- ets结合record的增删改查操作
- [erlang]ets结合record的增删改查操作
- ets结合record的增删改查操作
- ets结合record的增删改查操作
- [erlang]ets结合record的增删改查操作
- jfinal结合easyui完成基本的增删改查操作
- SSH结合EasyUI的分页操作(数据的增删改查)
- 增删查改操作
- Android中结合OrmLite for android组件对SQLite的CRUD(增删改查)操作实例
- Android中结合OrmLite for android组件对SQLite的CRUD(增删改查)操作实例
- Android中结合OrmLite for android组件对SQLite的CRUD(增删改查)操作实例
- Android中结合OrmLite for android组件对SQLite的CRUD(增删改查)操作实例
- 嵌套表的操作(增删改查)
- java操作mysql的增删改查
- java操作mysql的增删改查
- map的 增删改查 操作
- Magento基础的增删改查操作
- 在Ubuntu14.04中添加Windows风格的底部任务栏
- poj 2031 Building a Space Station
- 第一章计算机系统概述
- MyBatis入门指南
- 15个使用频率极高的基础算法题(附完整代码)
- ets结合record的增删改查操作
- QT 打开文件对话框总结
- SSU 479.Funny Feature
- Swift之闭包
- 凝固的音乐的建筑——淮南市山南新区展览馆
- Feldman + Quinones在哥伦比亚建造竹质儿童中心
- IOS 第三方库介绍
- php获取get/post请求的数据
- OMA设计:250米高烛台——深圳证券交易所