当前位置: 首页 > news >正文

NoSQL

NoSQL(Not Only SQL)是泛指非关系型数据库的统称,核心是放弃固定表结构、优先水平扩展 + 高可用 + 灵活 Schema,适合海量、高并发、非结构化 / 半结构化数据场景。


一、核心特点(vs 传统 SQL)

  • Schema 灵活:无需预定义表结构,字段可动态增减(SQL 需严格建表)。
  • 水平扩展:易通过加机器扩容(SQL 多为垂直扩容,分库分表复杂)。
  • BASE 而非 ACID
    • BasicallyAvailable(基本可用)
    • Soft state(软状态,允许短暂不一致)
    • Eventual consistency(最终一致性)(SQL 强一致、事务完整)。
  • 数据模型多样:键值、文档、列族、图等。

二、四大主流类型(含代表与场景)

1. 键值型(Key-Value)
  • 原理:哈希表,Key→Value,O (1) 读写。
  • 代表Redis(内存 + 持久化)、Memcached、DynamoDB。
  • 场景:缓存、Session、计数器、限流、排行榜。
2. 文档型(Document)
  • 原理:JSON/BSON/XML 文档,支持嵌套与二级索引。
  • 代表MongoDB、CouchDB、Couchbase。
  • 场景:内容管理、电商商品、用户画像、日志、App 后台。
3. 宽列 / 列族型(Wide-Column)
  • 原理:按列族存储,动态加列,稀疏数据友好,高写入吞吐。
  • 代表Cassandra、HBase、ScyllaDB。
  • 场景:时间序列、IoT 传感器、海量日志、推荐系统。
4. 图数据库(Graph)
  • 原理:节点(实体)+ 边(关系)+ 属性,高效关联查询。
  • 代表Neo4j、JanusGraph、ArangoDB。
  • 场景:社交网络、知识图谱、风控 / 反欺诈、路径分析。

三、核心理论

  • CAP 定理:分布式系统中,一致性 (C)、可用性 (A)、分区容错 (P)三者无法同时最优;NoSQL 常选AP(高可用)CP(强一致)
  • BASE 理论:NoSQL 设计基石,牺牲强一致换高可用与性能。

四、NoSQL vs SQL(选型参考)

表格

维度SQL(MySQL/Oracle)NoSQL(Mongo/Redis)
数据结构固定表、行 / 列、外键灵活 Schema、嵌套、无外键
一致性强一致(ACID)最终一致(BASE)
扩展垂直扩容、分库分表复杂水平扩容、分片原生支持
事务完整事务有限事务或无
适合场景金融交易、强一致、复杂关联查询海量数据、高并发、快速迭代、非结构化数据

五、常见误区与最佳实践

  • ❌ 误区:NoSQL 完全替代 SQL → ✅ 正确:混合架构(如 MySQL 存订单 + Redis 缓存 + Mongo 存用户行为)。
  • ❌ 误区:NoSQL 无事务 → ✅ 正确:MongoDB 支持多文档 ACID,Redis 支持事务 / 脚本。
  • ✅ 选型原则:
    1. 数据模型是否简单 / 半结构化?
    2. 是否需要超高并发读写?
    3. 一致性要求是否可接受 “最终一致”?
    4. 是否需要水平扩展能力?

六、学习路径建议

  1. 掌握Redis(键值,缓存 / 高并发必学)。
  2. 学习MongoDB(文档,最接近 SQL,易上手)。
  3. 了解Cassandra/HBase(宽列,大数据 / 时序场景)。
  4. 理解CAP/BASE、分片、复制、一致性哈希等分布式原理。
http://www.jsqmd.com/news/798386/

相关文章:

  • 别再死记公式了!用Python手把手教你计算语义分割的mIOU(附混淆矩阵代码详解)
  • 别再死记硬背PPP模型了!手把手带你拆解UC、UD、UofC和SD四大误差处理模型
  • QMCDecode终极指南:3步解锁QQ音乐加密文件,让音乐自由播放!
  • 泰坦之旅终极仓库管理神器:TQVaultAE完整功能解析与实战指南
  • AI建站工具从0到1全流程保姆级攻略:零代码生成网站就这么简单
  • TlbbGmTool:从数据库小白到《天龙八部》单机版管理大师的蜕变之旅
  • 六、利用ESP32搭建网络服务器(二):从基础响应到动态网页
  • 仅限前500名领取|Midjourney Encaustic风格专属权重包(含custom style token、texture overlay layer及CMYK预校准LUT)
  • 3个核心技术实现Layerdivider智能图像分层工具
  • Davinci vs. 其他BI工具怎么选?从私有化部署和二次开发角度深度对比
  • ESLyric歌词源终极指南:让Foobar2000享受三大音乐平台逐字歌词
  • 聚遇圈APP|告别孤独内耗,让有趣的人,恰好相遇
  • 保姆级教程:用QML为QGC地面站地图添加自定义飞行数据悬浮窗(附完整代码)
  • Cell:刘光慧等构建“衰老数字人体”方案,精准预测个体生物学年龄
  • 【游戏开发】UnLua实战:从蓝图到Lua,构建可热更的UE4游戏逻辑
  • 江苏泰海电气油浸式变压器屹立不倒的10个硬核生存能力 - GrowthUME
  • 告别示波器乱跳!深入解析TLC7528与STM32的时序配合,生成稳定模拟信号
  • 从原始寄存器到mg/g:LIS3DH加速度数据两种换算方法详解(含补码、移位与浮点运算对比)
  • ClaudeCode入门08-Git配合(小白入门:不知道怎么写Git提交记录?让AI自动帮你写好)
  • 实战:用flowcontainer+Python为你的网络流量数据打上“协议标签”与“行为指纹”
  • C# 之 ToString() 格式化实战:从基础占位符到高级自定义模式
  • 【实战指南】WebGoat General单元:从HTTP基础到代理抓包与开发者工具实战
  • ARM DAP调试架构核心机制与实践指南
  • 保姆级教程:手把手用Wireshark抓包分析GB28181语音对讲的SIP信令与RTP流
  • B站字幕提取三连击:如何用命令行工具实现零门槛视频知识管理
  • IPXWrapper完整指南:让经典游戏在Windows 10/11重获网络对战能力
  • 《初学Java语言》第一讲:与C语言相同的不同之处
  • NotebookLM音频能力全景图(2024Q2实测版):97%用户忽略的语音语义对齐漏洞与修复指南
  • 学习进度4/15
  • 微服务最可怕的不是拆分,而是数据库“慢性死亡”