适用于PHP的轻量级数据库

1. PHP 支持 SQLite 数据库

PHP 原生支持 SQLite 数据库,非常适合小型 Web 应用。SQLite 是一个轻量级、无服务器的关系型数据库,使用单个文件存储数据,适合嵌入式和小型项目。

如何在 PHP 中使用 SQLite

  1. 检查环境支持
    PHP 内置了对 SQLite 的支持,确保你安装了 PHP 的 pdo_sqlitesqlite3 扩展。

    php -m | grep sqlite
    

    如果没有显示,需在 php.ini 中启用:

    extension=pdo_sqlite
    extension=sqlite3
    
  2. 示例代码:操作 SQLite 数据库

    <?php
    // 创建/连接 SQLite 数据库文件
    $db = new PDO('sqlite:my_database.sqlite');
    
    // 创建表
    $db->exec("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)");
    
    // 插入数据
    $db->exec("INSERT INTO users (name, age) VALUES ('Alice', 30), ('Bob', 25)");
    
    // 查询数据
    $result = $db->query("SELECT * FROM users");
    foreach ($result as $row) {
        echo "ID: {$row['id']}, Name: {$row['name']}, Age: {$row['age']}<br>";
    }
    
    // 关闭连接
    $db = null;
    ?>
    

2. 类似 SQLite 的单文件数据库推荐

(1) JSON 文件

  • 适用场景:极小型项目,简单的数据存储。
  • 特点
    • 无需数据库,直接读写 JSON 文件。
    • 性能好,适合低并发场景。
  • 示例代码
    <?php
    $file = 'data.json';
    
    // 写入数据
    $data = [
        ['id' => 1, 'name' => 'Alice', 'age' => 30],
        ['id' => 2, 'name' => 'Bob', 'age' => 25]
    ];
    file_put_contents($file, json_encode($data));
    
    // 读取数据
    $content = file_get_contents($file);
    $users = json_decode($content, true);
    print_r($users);
    ?>
    

(2) FlatfileDB (基于 PHP 的简单数据库库)

(3) TinyDB

  • 适用场景:替代 JSON 文件存储,用于 Web App 中更复杂的数据管理。
  • 特点
    • Python 原生开发,支持简单的数据存储操作。
    • 数据保存在 JSON 文件中。
    • PHP 可通过 REST API 集成。

(4) LowDB

  • 适用场景:JavaScript 和 PHP 项目的跨语言数据存储。
  • 特点
    • 基于 JSON 的单文件数据库。
    • 使用简单,适合小型应用。

(5) LiteDB (C#,可通过 API 集成)

  • 适用场景:跨语言集成需求。
  • 特点
    • 单文件数据库,基于 BSON(类似 MongoDB)。
    • 性能优秀,适合中小型 Web 应用。

3. 选择建议

数据库/存储方式 适用场景 特点
SQLite 小型项目,单文件存储 轻量级,支持 SQL,稳定可靠
JSON 文件 极简存储,配置文件 无需依赖,适合低并发小项目
FlatfileDB 简单数据存储,结构化数据 无需服务器,文件系统友好
TinyDB 小型数据存储,JSON 格式 灵活易用,适合多平台
LiteDB 更复杂的单文件需求 性能好,但需通过 API 集成

总结

  • 如果需要 SQL 功能并追求稳定性,SQLite 是最佳选择。
  • 如果只需要简单的键值对或列表,JSON 文件FlatfileDB 是轻量级的选择。
  • 如果需要更高性能或特定语言支持,可以考虑 LiteDB 等选项。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容