NoSQL入门指南:Redis与MongoDB的Java实战

一、为什么需要NoSQL?

在传统SQL数据库中,数据必须严格遵循预定义的表结构,就像把所有物品整齐摆放在固定尺寸的货架上。而NoSQL(Not Only SQL)数据库则像一个灵活的储物间,允许存储各种类型的数据,无需提前规划结构。

NoSQL的核心特点:

  • 非关系型:无需预定义表结构
  • 分布式:天然支持水平扩展
  • 高性能:适合处理海量数据
  • 灵活存储:支持键值、文档、列族等多种格式

二、Redis:内存中的超级储物柜

1. 核心特性

  • 数据类型丰富:支持字符串、哈希、列表、集合、有序集合等
  • 内存存储:读写速度极快(10万+操作/秒)
  • 持久化:支持RDB快照和AOF日志

2. Java操作示例

添加依赖(Maven)
<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>4.3.1</version>
</dependency>
基本操作代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction;public class RedisExample {public static void main(String[] args) {try (Jedis jedis = new Jedis("localhost", 6379)) {// 存储用户信息jedis.set("user:1001", "{\"name\":\"张三\",\"age\":25}");// 存储哈希数据jedis.hset("user:1001:profile", "email", "zhangsan@example.com");jedis.hset("user:1001:profile", "phone", "13812345678");// 自增计数器jedis.incr("post:view:100");  // 阅读量+1// 有序集合存储排行榜jedis.zadd("rank:score", 95, "李四");jedis.zadd("rank:score", 88, "王五");// 事务操作Transaction transaction = jedis.multi();transaction.incr("counter");transaction.exec();}}
}

3. 典型应用场景

  • 缓存系统:存储高频访问数据
  • 会话管理:存储用户会话信息
  • 计数器:统计文章阅读量、点赞数
  • 实时消息:使用Pub/Sub功能实现消息队列

三、MongoDB:灵活的文档数据库

1. 核心特性

  • 文档存储:使用BSON格式存储半结构化数据
  • 动态模式:无需预定义字段
  • 水平扩展:支持分片集群
  • 强大查询:支持复杂的聚合操作

2. Java操作示例

添加依赖(Maven)
<dependency><groupId>org.mongodb</groupId><artifactId>mongodb-driver-sync</artifactId><version>4.6.0</version>
</dependency>
基本操作代码
import com.mongodb.MongoClientSettings;
import com.mongodb.client.*;
import org.bson.Document;
import org.bson.codecs.configuration.CodecRegistry;
import org.bson.codecs.pojo.PojoCodecProvider;import java.util.Arrays;import static org.bson.codecs.configuration.CodecRegistries.fromProviders;
import static org.bson.codecs.configuration.CodecRegistries.fromRegistries;public class MongoDBExample {public static void main(String[] args) {// 配置POJO映射CodecRegistry pojoCodecRegistry = fromProviders(PojoCodecProvider.builder().automatic(true).build());CodecRegistry codecRegistry = fromRegistries(MongoClientSettings.getDefaultCodecRegistry(), pojoCodecRegistry);// 连接MongoDBtry (MongoClient mongoClient = MongoClients.create(MongoClientSettings.builder().codecRegistry(codecRegistry).applyToClusterSettings(builder ->builder.hosts(Arrays.asList(new ServerAddress("localhost", 27017)))).build())) {MongoDatabase database = mongoClient.getDatabase("mydatabase");MongoCollection<User> collection = database.getCollection("users", User.class);// 插入文档User user = new User("张三", 25, "zhangsan@example.com", new Address("长安街1号", "北京"));collection.insertOne(user);// 查询文档FindIterable<User> results = collection.find(Filters.eq("name", "张三"));for (User u : results) {System.out.println(u);}// 更新文档collection.updateOne(Filters.eq("name", "张三"),Updates.set("age", 26));// 聚合查询AggregateIterable<Document> aggregate = collection.aggregate(Arrays.asList(Aggregates.match(Filters.gte("age", 18)),Aggregates.group("$address.city", Accumulators.sum("count", 1))));for (Document doc : aggregate) {System.out.println(doc);}}}
}// 定义实体类
class User {private String name;private int age;private String email;private Address address;// 构造方法、getter/setter省略
}class Address {private String street;private String city;// 构造方法、getter/setter省略
}

3. 典型应用场景

  • 日志记录:存储非结构化日志数据
  • 内容管理:存储文章、评论等
  • 电商订单:存储包含复杂属性的订单
  • 实时分析:使用聚合框架处理海量数据

四、Redis vs MongoDB:如何选择?

特性RedisMongoDB
数据模型键值对(支持丰富数据结构)文档型(BSON格式)
存储位置内存优先磁盘存储
查询能力简单查询复杂查询+聚合
扩展性主从复制+哨兵分片集群
适用场景缓存、计数器、实时消息日志、内容管理、实时分析

五、总结

NoSQL数据库为现代应用提供了更灵活的数据存储方式:

  • Redis适合需要高性能读写的场景
  • MongoDB适合处理半结构化数据和复杂查询
  • 传统SQL适合需要事务支持的场景

建议根据具体业务需求选择合适的工具,必要时可以混合使用多种数据库。

六、推荐学习资源

  1. Redis Java客户端文档
  2. MongoDB Java驱动文档
  3. 《Redis实战》
  4. 《MongoDB权威指南》

现在就动手用Java操作Redis和MongoDB,体验NoSQL的灵活性吧!🚀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/901310.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 列表初始化全解析:7种方式详解与最佳实践

文章目录 **引言****1. 传统逐个添加元素****特点****注意事项** **2. Arrays.asList() 构造函数****特点****注意事项** **3. 双括号初始化&#xff08;匿名内部类&#xff09;****特点****注意事项** **4. Java 9 List.of()&#xff08;不可变列表&#xff09;****特点****注…

最大公约数和最小倍数 java

在Java中&#xff0c;计算两个数的最大公约数&#xff08;Greatest Common Divisor, GCD&#xff09;和最小公倍数&#xff08;Least Common Multiple, LCM&#xff09;是常见的编程问题。以下是具体的实现方法和代码示例。 --- ### **1. 最大公约数 (GCD)** 最大公约数是指…

数据库——视图

一、视图的定义与核心特性 1.基本概念 (1)视图(View)是基于一个或多个底层表(或视图)的虚拟表,其本身不存储数据,仅保存查询语句的定义。当用户查询视图时,数据库会动态执行其封装的SQL语句,生成结果集。 (2)本质:视图是底层表的逻辑映射,结构与表相同(由行和列…

【Proteus仿真】【32单片机-A008】MPX4115压力检测系统设计

目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 联系作者 一、主要功能 1、压力检测与LCD显示 2、超过上限&#xff0c;降压模块启动 3、压力检测范围15kpa-115kpa 4、压力阈值设置 5、超限报警 二、使用步骤 系统运行后&#xff0c;LCD160…

java和c#的相似及区别基础对比

用过十几种语言&#xff0c;但是java和c#是最为重要的两门。c#发明人曾主导开发了pascal和delphi&#xff0c;加入微软后&#xff0c;参考了c和java完成了c#和net。大家用过java或c#任意一种的&#xff0c;可以通过本篇文章快速掌握另外一门语言。 基础语法 变量声明&#xf…

OpenBayes 一周速览|1分钟生成完整音乐,DiffRhythm人声伴奏一键搞定; Stable Virtual Camera重塑3D视频创作

公共资源速递 5 个数据集&#xff1a; * 302 例罕见病病例数据集 * DRfold2 RNA 结构测试数据集 * NaturalReasoning 自然推理数据集 * VenusMutHub 蛋白质突变小样本数据集 * Bird Vs Drone 鸟类与无人机图像分类数据集 2 个模型&#xff1a; * Qwen2.5-0mni * Llama…

PostgreSQL 实例运行状态全面检查

PostgreSQL 实例运行状态全面检查 PostgreSQL 实例的健康检查是数据库运维的核心工作&#xff0c;以下是系统化的状态检查方法和关键指标解读。 一 基础健康检查 1.1 实例可用性检查 # 快速连接测试 pg_isready -h localhost -p 5432 -U postgres -d postgres# 返回状态说明…

利用 Python 进行股票数据可视化分析

在金融市场中&#xff0c;股票数据的可视化分析对于投资者和分析师来说至关重要。通过可视化&#xff0c;我们可以更直观地观察股票价格的走势、交易量的变化以及不同股票之间的相关性等。 Python 作为一种功能强大的编程语言&#xff0c;拥有丰富的数据处理和可视化库&#xf…

时序约束高级进阶使用详解二:Set_Min_Delay

目录 一、前言 二、设计示例 2.1 示例代码 2.2 时序约束 三、Set_min_delay 3.1 start points 3.1.1 对象有效性 3.1.2 边沿有效性 3.1.3 start point非有效起点 3.2 Through points 3.2.1 约束对象为Cells 3.2.2 约束对象为Cell pin/Net 3.3 to points 3.4 rise…

2025-4-12-C++ 学习 XOR 三元组 异或 急转弯问题

C的学习必须更加精进一些&#xff0c;对于好多的函数和库的了解必须深入一些。 文章目录 3513. 不同 XOR 三元组的数目 I题解代码 3514. 不同 XOR 三元组的数目 II题解代码 晚上&#xff0c;10点半&#xff0c;参加了LC的竞赛&#xff0c;ok了一道&#xff0c;哈哈~   第二道…

图像形态学操作对比(Opencv)

形态学基于图像的形状进行操作&#xff0c;用于处理二值化图像&#xff0c;主要包括腐蚀和膨胀两种基本操作。这些操作通常用于去除噪声、分隔或连接相邻的元素以及寻找图像中显著的最大点和最小点。 1. 形态学操作 import cv2 import numpy as np import matplotlib.pyplot …

sql 向Java的映射

优化建议&#xff0c;可以在SQL中控制它的类型 在 MyBatis 中&#xff0c;如果返回值类型设置为 java.util.Map&#xff0c;默认情况下可以返回 多行多列的数据

excel中的VBA指令示例(一)

示例注释&#xff1a; Sub 宏1() sub是宏开头&#xff0c;宏1是宏的名称&#xff0c;自定义&#xff0c;在按钮中可指定用某个宏 后面是注释 Sheets("装配材料").Select ‘选择表 装配材料 Ce…

【Linux C】简单bash设计

主要功能 循环提示用户输入命令&#xff08;minibash$&#xff09;。创建子进程&#xff08;fork()&#xff09;执行命令&#xff08;execlp&#xff09;。父进程等待子进程结束&#xff08;waitpid&#xff09;。关键问题 参数处理缺失&#xff1a;scanf("%s", buf)…

【vue】基础

一、vi-if 1.1基本使用 必须绑定大盒子包住的代码&#xff0c;使用id或者class都可以进行绑定 new Vue({ el:"#id" el:".class" }) 1.2v-if和v-show的区别 v-show会渲染&#xff0c;但是不显示&#xff0c;v-if不渲染不显示 1.3vue实例的作用范围 必须包…

【数据结构_5】链表(模拟实现以及leetcode上链表相关的题目)

书接上文&#xff0c;继续编写链表的功能 4.链表的中间插入 在链表中&#xff0c;本身是没有下标这样的概念的&#xff0c;不像顺序表&#xff0c;顺序表根据下标访问元素&#xff0c;O(1)复杂度。链表需要遍历之后找到正确的位置才能进行插入&#xff0c;为O&#xff08;N&a…

C语言的发展史

一、起源 C语言的起源可以追溯到20世纪60年代末期。其前身是BCPL&#xff08;Basic Combined Programming Language&#xff09;语言&#xff0c;由剑桥大学的Martin Richards于1967年在CPL语言的基础上简化而来。1970年&#xff0c;美国贝尔实验室的Ken Thompson以BCPL语言为…

深入解析栈式虚拟机与反向波兰表示法

1.1 什么是虚拟机&#xff1f; 虚拟机&#xff08;Virtual Machine, VM&#xff09;是一种软件实现的计算机系统&#xff0c;提供与物理计算机相类似的环境&#xff0c;但在软件层面运行。虚拟机的存在简化了跨平台兼容性、资源管理以及安全隔离等问题。 1.2 栈式虚拟机的架构…

ubuntu 系统安装Mysql

安装 mysql sudo apt update sudo apt install mysql-server 启动服务 sudo systemctl start mysql 设置为开机自启 sudo systemctl enable mysql 查看服务状态 &#xff08;看到类似“active (running)”的状态信息代表成功&#xff09; sudo systemctl status mysql …

《前端面试题之 CSS篇(第一集)》

目录 1、CSS的盒模型2、CSS选择器及其优先级3、隐藏元素的方法有那些4、px、em、rem的区别及使用场景5、重排、重绘有什么区别6、水平垂直居中的实现7、CSS中可继承与不可继承属性有哪些8、Sass、Less 是什么&#xff1f;为什么要使用他们&#xff1f;9、CSS预处理器/后处理器是…