码迷,mamicode.com
首页 > 其他好文 > 详细

[Erlang之旅 0005] ETS 和Record

时间:2014-08-14 23:18:36      阅读:331      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   使用   os   io   数据   for   

ETS 提供“键-值” 搜索表, 驻留在内存中,速度较快。是缓存的大利器。

record 作为erlang的一种数据结构,通常用于函数量传递。

ETS中创建表, 对数据进行增、删、改、查 , 及关闭表常用的函数

   ets:new(Name, Options) -> tid()   %% 创建表

           Options:

       Type: set | ordered_set | bag | duplicate_bag

         set: 每一个元组的键值都不能相同;ordered_set:元组键不能相同,并且会进行排序

                          bag:多个元组有相同的键,但是不能完全相同;duplicate_bag:允许多个元组有相同的键,而且可以完全相同。

                   Access:public | protected | private

         public:公开表, 所有知道这个表标识的进程都可以对这个表进行读写操作

         protected:受保护的表, 知道表标识的进程只可以读操作,但是这个表的所有者进程可以进行读写操作。

         private:私有表,只有所有者进程可以读写这个表。

                   named_table:命名表,如果存在这个选项,则后续操作中使用Name来操作表。

                  {keypos, Pos}:用Pos作为主键,默认情况下是第一位置。在使用record的时候,需要用到这个选项

 

 ets:insert(Tab, ObjectOrObjects) -> true                  %%表内插入一条数据

 ets:delete(Tab, Key) -> true                                    %%删除表内指定key的数据

 ets:delete_all_objectes(Tab) -> true                         %%删除表内所有数据

 ets:update_element(Tab, Key, ElementSpec :: {Pos, Value}) -> boolean()     %%Pos=integer() >=1  更新数据

 ets:lookup(Tab, Key) -> [Object]                             %%按照key查找表内的数据

 ets:delete(Tab) -> true                                            %%删除表

下面的一个例子来实现这些功能

1> rd(student, {id, name, pwd, age, sex=man}).                         %%定义一个record
student
2> ets:new(stu, [set, public, named_table, {keypos, #student.id}]).     %%创建一个table
stu
3> Stu1=#student{id=‘0001‘, name=nike, pwd=‘0001‘, age=18}.             %% 创建一个record
#student{id = ‘0001‘,name = nike,pwd = ‘0001‘,age = 18,
         sex = man}
4> ets:insert(stu, Stu1).                                               %% 向Table中添加一条数据
true
5> ets:lookup(stu, ‘0001‘).                                              %% 查找数据
[#student{id = ‘0001‘,name = nike,pwd = ‘0001‘,age = 18,
          sex = man}]
6> io:format("~p~n",[ets:tab2list(stu)]).                                %% 打印table 中的数据
[{student,‘0001‘,nike,‘0001‘,18,man}]
ok
7> ets:lookup(stu, ‘0001‘).
[#student{id = ‘0001‘,name = nike,pwd = ‘0001‘,age = 18,
          sex = man}]
8> ets:update_element(stu,‘0001‘,{#student.pwd, ‘nike‘}).                %% 更新数据
true
9> ets:lookup(stu, ‘0001‘).
[#student{id = ‘0001‘,name = nike,pwd = nike,age = 18,
          sex = man}]
10> ets:delete(stu, ‘0001‘).
true
11> ets:lookup(stu, ‘0001‘).                                             %% 删除数据
[]
12> ets:delete(stu).                                                     %% 删除表
true
13> 

[Erlang之旅 0005] ETS 和Record,布布扣,bubuko.com

[Erlang之旅 0005] ETS 和Record

标签:style   blog   color   使用   os   io   数据   for   

原文地址:http://www.cnblogs.com/hanbird/p/3844860.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!