zoukankan      html  css  js  c++  java
  • ets结合record的增删改查操作

    摘自 http://www.iteye.com/topic/689089

    
    
    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

  • 相关阅读:
    Hive(二)CentOS7.5安装Hive2.3.3
    Hive(一)Hive初识
    CentOS7.5搭建ELK6.2.4集群及插件安装
    开发工具之Spark程序开发详解
    Java多线程编程
    数据迁移之Sqoop
    CentOS7.5之Sqoop1.4.7的安装使用
    Hadoop案例(十一)MapReduce的API使用
    Hadoop案例(十)WordCount
    BSScrollViewEdgePop
  • 原文地址:https://www.cnblogs.com/ShankYan/p/5393826.html
Copyright © 2011-2022 走看看