博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Erlang脚印 0005] ETS 和Record
阅读量:6653 次
发布时间:2019-06-25

本文共 2188 字,大约阅读时间需要 7 分钟。

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}).                         %%定义一个recordstudent2> ets:new(stu, [set, public, named_table, {keypos, #student.id}]).     %%创建一个tablestu3> 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中添加一条数据true5> 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}]ok7> ets:lookup(stu, '0001').[#student{id = '0001',name = nike,pwd = '0001',age = 18,          sex = man}]8> ets:update_element(stu,'0001',{#student.pwd, 'nike'}).                %% 更新数据true9> ets:lookup(stu, '0001').[#student{id = '0001',name = nike,pwd = nike,age = 18,          sex = man}]10> ets:delete(stu, '0001').true11> ets:lookup(stu, '0001').                                             %% 删除数据[]12> ets:delete(stu).                                                     %% 删除表true13>

转载于:https://www.cnblogs.com/hanbird/p/3844860.html

你可能感兴趣的文章
leetcode -- Maximal Rectangle TODO O(N)
查看>>
C# 深复制
查看>>
GNU风格 ARM汇编语法2
查看>>
Scala 常用语法
查看>>
Ubuntu系统下添加程序启动器
查看>>
babyClock 1.0发布(Android2.2以上)
查看>>
android与javascript相互调用
查看>>
头文件 boost/cstdint.hpp
查看>>
设计模式之建造者模式(七)
查看>>
我开发共享软件的三次经历(上):打造一款很多人用的软件
查看>>
iOS应用程序生命周期(前后台切换,应用的各种状态)详解
查看>>
谷歌调试工具祝你一臂之力买火车票,简单安全方便
查看>>
传输层
查看>>
优秀Python学习资源收集汇总(强烈推荐)
查看>>
解决office2007-安装程序找不到office.zh-cn\Setup.xml
查看>>
2013年最值得我们学习的网页作品示例【系列六】
查看>>
C++的那些事:容器和泛型算法
查看>>
安装elasticsearch
查看>>
java中POJO类和DTO类都要实现序列化
查看>>
asp 支付宝 企业版 接口 支持网银接口 ,网银直接支付
查看>>