搜尋
首頁資料庫mysql教程Mnesia数据库操作整理(1)

Mnesia数据库的操作和以前习惯的SQL数据库操作几乎完全不同,刚开始用很不使用。现将常见的读写操作整理于下: 1、脏读 mnesia:dirty_read(Tab,Key)-ValueList | exit({aborted,Reason}) 示例: 对于set类型的表,这个操作返回一个或者空表,因为set类型表键

Mnesia数据库的操作和以前习惯的SQL数据库操作几乎完全不同,刚开始用很不使用。现将常见的读写操作整理于下:

1、脏读

mnesia:dirty_read(Tab,Key)->ValueList | exit({aborted,Reason})

示例:

Mnesia数据库操作整理(1)


对于set类型的表,这个操作返回一个值或者空表,因为set类型表键值不可重复。如果对bag类型(键值可重复,但不能同键又同值)用脏读,结果是一个或若干值的列表,一个值都没有就是个空表。

示例:

Mnesia数据库操作整理(1)


2、脏写

mnesia:dirty_write(Tab,Record) -> ok | exit({abouted,Reason})

示例:

Mnesia数据库操作整理(1)


3、读read

这个操作,只能用在事务中,所以也不能直接在shell里使用。

示例:

Mnesia数据库操作整理(1)


4、写write

同上,普通的写操作也必须在事务中完成,否则会报错。

示例:

Mnesia数据库操作整理(1)


小结:read和write都是用于事务的,在不使用事务的时候,直接用dirty_read和dirty_write。

另,以上2种读操作都是按照主键进行查询。


5、使用带匹配规范的mnesia:select

Mnesia数据库操作整理(1)

Mnesia数据库操作整理(1)

这个命令也必须放到事务中才能执行。第一个参数是要查询的表,第二个参数是匹配规范。是个{Head,Conditions,Results}格式的三元组。

Head是个Erlang项式,用于描述查询模式,其中的'$1','$2'等原子用于表示变量,其对应于记录中第一个、第二个字段,以此类推。


‘_’(仅仅限于在Head部分使用),表示无所谓,任意值都可以匹配,示例:

Mnesia数据库操作整理(1)


'$$'(仅仅限于Results和Conditions中使用),等价于罗列出依次在Head部分匹配的所有变量'$1','$1','$1'等,示例参见上图。这个主要用于我们只对查询结果的部分字段感兴趣的时候用,不需要把整条记录都选择出来。


'$_'(仅仅限于Results和Conditions中使用),表示与查询条件相匹配的整条记录,示例:

Mnesia数据库操作整理(1)


6、使用查询列表速构(QLC)

QLC的全称是Query List Comprehension。表面看,它类似于普通的列表速构,使用时,又必须嵌套于外观类似于函数调用的qlc:q()中使用。实际上外层的qlc:q(...)只是一个标记,用于让编译器区别对待其中的表达式。要启用该功能,模块源码中必须加上下面这一行:

-include_lib("stdlib/include/qlc.hrl").

但作为特例,可以直接在Erlang shell中使用qlc:q(...)。也可以在事务中使用QLC,任何可以在事务中使用的Mnesia函数都可以与QLC混合使用。


示例:

Mnesia数据库操作整理(1)

上图是仅仅获取users表中的acc字段。


Mnesia数据库操作整理(1)

这是获取users表中的整条记录。


有关QLC的更多复杂用法,可以参见Erlang之父Joe Armstrong的新作《Programming Erlang, 2nd》第20章,“Mnesia:The Erlang Database”,326页。其中涉及到比如“2个表联合查询”。


QLC在erl源码中的用法示例:

Mnesia数据库操作整理(1)


7、删除mnesia:delete

要从数据库删除一行,需要知道该行的对象ID(OID)。对象ID由一个由表名和主键构成的二元组。

示例:

Mnesia数据库操作整理(1)


8、更新操作

Mnesia数据表里没有UPDATE的概念,如果要修改某条记录,根据表的不同类型,可以先删除,再插入新的记录,或者直接添加新记录代替旧的记录。


9、事务操作

事务代码的结构:

Mnesia数据库操作整理(1)


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在MySQL中使用視圖的局限性是什麼?在MySQL中使用視圖的局限性是什麼?May 14, 2025 am 12:10 AM

mysqlviewshavelimitations:1)他們不使用Supportallsqloperations,限制DatamanipulationThroughViewSwithJoinsOrsubqueries.2)他們canimpactperformance,尤其是withcomplexcomplexclexeriesorlargedatasets.3)

確保您的MySQL數據庫:添加用戶並授予特權確保您的MySQL數據庫:添加用戶並授予特權May 14, 2025 am 12:09 AM

porthusermanagementinmysqliscialforenhancingsEcurityAndsingsmenting效率databaseoperation.1)usecReateusertoAddusers,指定connectionsourcewith@'localhost'or@'%'。

哪些因素會影響我可以在MySQL中使用的觸發器數量?哪些因素會影響我可以在MySQL中使用的觸發器數量?May 14, 2025 am 12:08 AM

mysqldoes notimposeahardlimitontriggers,butacticalfactorsdeterminetheireffactective:1)serverConfiguration impactactStriggerGermanagement; 2)複雜的TriggerSincreaseSySystemsystem load; 3)largertablesslowtriggerperfermance; 4)highConconcConcrencerCancancancancanceTigrignecentign; 5); 5)

mysql:存儲斑點安全嗎?mysql:存儲斑點安全嗎?May 14, 2025 am 12:07 AM

Yes,it'ssafetostoreBLOBdatainMySQL,butconsiderthesefactors:1)StorageSpace:BLOBscanconsumesignificantspace,potentiallyincreasingcostsandslowingperformance.2)Performance:LargerrowsizesduetoBLOBsmayslowdownqueries.3)BackupandRecovery:Theseprocessescanbe

mySQL:通過PHP Web界面添加用戶mySQL:通過PHP Web界面添加用戶May 14, 2025 am 12:04 AM

通過PHP網頁界面添加MySQL用戶可以使用MySQLi擴展。步驟如下:1.連接MySQL數據庫,使用MySQLi擴展。 2.創建用戶,使用CREATEUSER語句,並使用PASSWORD()函數加密密碼。 3.防止SQL注入,使用mysqli_real_escape_string()函數處理用戶輸入。 4.為新用戶分配權限,使用GRANT語句。

mysql:blob和其他無-SQL存儲,有什麼區別?mysql:blob和其他無-SQL存儲,有什麼區別?May 13, 2025 am 12:14 AM

mysql'sblobissuitableForStoringBinaryDataWithInareLationalDatabase,而ilenosqloptionslikemongodb,redis和calablesolutionsolutionsolutionsoluntionsoluntionsolundortionsolunsonstructureddata.blobobobissimplobisslowdeperformberbutslowderformandperformancewithlararengedata;

mySQL添加用戶:語法,選項和安全性最佳實踐mySQL添加用戶:語法,選項和安全性最佳實踐May 13, 2025 am 12:12 AM

toaddauserinmysql,使用:createUser'username'@'host'Indessify'password'; there'showtodoitsecurely:1)choosethehostcarecarefullytocon trolaccess.2)setResourcelimitswithoptionslikemax_queries_per_hour.3)usestrong,iniquepasswords.4)Enforcessl/tlsconnectionswith

MySQL:如何避免字符串數據類型常見錯誤?MySQL:如何避免字符串數據類型常見錯誤?May 13, 2025 am 12:09 AM

toAvoidCommonMistakeswithStringDatatatPesInMysQl,CloseStringTypenuances,chosethirtightType,andManageEngencodingAndCollat​​ionsEttingSefectery.1)usecharforfixed lengengtrings,varchar forvariable-varchar forbariaible length,andtext/blobforlargerdataa.2 seterters seterters seterters

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具