Linux 数据库开发 学习笔记

数据库介绍

什么是数据库?

数据库是结构化数据集合,支持高效存储、管理和检索,可以持久存储数据,提供安全、可靠、高效的数据访问机制

为什么需要数据库?

•数据持久化:程序重启后数据不丢失

•数据共享:多用户/应用可并发访问

•数据一致性:通过事务机制(ACID)保证数据完整性

•高效查询:通过索引、优化器加速数据检索

数据库的发展

数据库分类

主流关系型数据库对比

数据库 优势 缺点
MySQL • 开源免费,社区活跃 • 高并发读写优化(OLTP场景) • 易部署,轻量级 • 复杂查询性能较弱(如多表JOIN) • 功能扩展性有限(相比PostgreSQL)
PostgreSQL • 功能全面(支持JSON、GIS、全文检索等) • 高度可扩展(自定义数据类型、函数) • ACID兼容性强 • 默认配置下高并发性能略逊于MySQL • 内存消耗较高
Oracle • 企业级性能(高可用、分布式优化) • 强大的事务处理与锁机制 • 完善的商业支持与工具链 • 高昂成本(商业授权) • 学习曲线陡峭,管理复杂
SQL Server • 与Windows生态深度集成(.NET、Azure) • 图形化管理工具(SSMS)易用 • 内置BI工具(SSAS、SSRS) • 仅支持Windows/Linux(有限跨平台) • 社区版功能受限
SQLite • 零配置,嵌入式数据库(单文件) • 轻量级(库文件仅数MB) • 无服务端,适合本地存储 • 不支持高并发(写锁全局) • 无用户权限管理 • 数据量不宜过大,SQL执行效率相对较低
MongoDB(文档型) • 灵活模式(JSON文档结构) • 水平扩展(分片集群) • 丰富的查询语言(类SQL语法) • 支持多文档事务(4.0+) • 内存消耗较高 • 复杂关联查询性能弱于关系型数据库
Redis(键值型) • 内存存储,超高性能(10万+ QPS) • 支持多种数据结构(字符串、哈希、列表等) • 持久化(RDB/AOF)与高可用(哨兵/集群) • 数据规模受内存限制 • 无复杂查询能力(仅键查询) • 高并发写入可能丢数据(异步持久化)
Neo4j(图数据库) • 高效处理复杂关系(原生图存储) • 强大的图查询语言(Cypher) • ACID事务支持 • 扩展性受限(社区版单机) • 存储非图数据效率低

数据库安装

软件在线安装sudo apt-getinstallsqlite3(软件)libsqlite3-dev(函数库)

相关推荐
LinXunFeng1 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
通信小呆呆6 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick6 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee6 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn866 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e6 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
小雨下雨的雨6 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙
闪闪发亮的小星星6 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq6 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
YangYang9YangYan6 天前
2026初入职场学习数据分析的价值
学习·数据挖掘·数据分析