摘要
本实验报告聚焦于"大数据技术原理"课程中的NoSQL数据库实验。实验环境包括MySQL、Redis、MongoDB、Java以及Hadoop。实验内容涉及Redis和MongoDB的安装、配置和基本操作,包括数据的插入、删除和查询。此外,实验还包括使用Java API对MongoDB进行访问和操作。
在Redis部分,实验详细记录了从下载、安装到通过命令行与Redis交互的全过程。在MongoDB部分,实验不仅涵盖了MongoDB的安装和基本Shell命令的使用,还包括了使用Java API与MongoDB交互的实践。实验中遇到的问题包括键值对的选择、中文字符处理以及MongoDB版本和集合管理等,这些问题均通过相应的解决方案得到妥善处理。
总体强调了Redis作为缓存数据库的优势,以及MongoDB作为文档型NoSQL数据库的特点。Redis以其快速的读取速度和高效的运行效率著称,而MongoDB以其灵活的模式和丰富的查询语言为开发者提供了强大的数据处理能力。
关键词:NoSQL数据库;Redis;MongoDB;Java API;大数据技术
一.实验环境:
- MySQL
- Redis
- MongDB
- JAVA和Hadoop
二.实验内容与完成情况:
Redis的安装和使用。完成数据库的插入,删除,以及查询:
1.下载到对应文件夹:
data:image/s3,"s3://crabby-images/a5d83/a5d831891194f67f6a781444e98fe8a63b0798a1" alt=""
2.输入命令安装redis:
data:image/s3,"s3://crabby-images/c1ec1/c1ec1910215e73d4733037a997425ca1052e51e0" alt=""
3.打开redis服务器:
data:image/s3,"s3://crabby-images/643e4/643e4c04de5d627bfe3c6f88c713189823758318" alt=""
4.进入redis客户端:
data:image/s3,"s3://crabby-images/a3bf2/a3bf26f82681e5269ccb3027f35efc96793923c0" alt=""
5.使用键值对:
data:image/s3,"s3://crabby-images/5bf82/5bf820a92e905d17b82fac2c5489e3f974357a47" alt=""
6.创建表:
data:image/s3,"s3://crabby-images/8447d/8447d660b26b812ed25d1175eedac6b9613844eb" alt=""
7.插入数据:
data:image/s3,"s3://crabby-images/013a6/013a60d7f84e1eebdcbc131df091d66a248d685e" alt=""
8.删除数据:
data:image/s3,"s3://crabby-images/308dc/308dc7eae129b8d71e2305e76daafcead858a153" alt=""
MongoDB的安装和使用。完成MongoDB的基本的shell命令
1.使用软件源安装MongoDB:
data:image/s3,"s3://crabby-images/3b80a/3b80ac44771ca4e9f26775564707ebe50f1b347f" alt=""
2.创建MongoDB文件列表:
data:image/s3,"s3://crabby-images/42073/420732b0b3e6a3fc39a06973943a7999102a727f" alt=""
3.安装MongoDB:
data:image/s3,"s3://crabby-images/4f2fb/4f2fb629e5b47d71a430743dad20a2481c583096" alt=""
data:image/s3,"s3://crabby-images/d40be/d40be9f09108432ae01e1c2ae64cd845224af9b6" alt=""
data:image/s3,"s3://crabby-images/a423c/a423c69ac46e2c466124249b6773d8959c1192e4" alt=""
data:image/s3,"s3://crabby-images/5efac/5efac365b0b4d72868d5778e3881182af182b90b" alt=""
4.启动MongoDB:
data:image/s3,"s3://crabby-images/9fae4/9fae47aff73a8fd021b2e8721e4e4eed0f287c9a" alt=""
5.shell命令:
data:image/s3,"s3://crabby-images/65b5e/65b5e11038f7a061885a2fea94c9994c4813a129" alt=""
6.常见命令:
展现数据库、使用数据库、创建集合
data:image/s3,"s3://crabby-images/5b14f/5b14f9ca64e0232427dd1384a59c15309d55a397" alt=""
7.插入数据:
data:image/s3,"s3://crabby-images/9da0a/9da0a0cfb167cbb434dc333d7aab3f857837c578" alt=""
8.查询所有记录:
data:image/s3,"s3://crabby-images/ca190/ca190f5b9d10f497f89feb92b649548524d3f413" alt=""
9.查询指定记录:
data:image/s3,"s3://crabby-images/0871c/0871c97f4219ed1696c1bf846d201c61ea26d2a9" alt=""
10.查询指定列、sname、sage数据:
data:image/s3,"s3://crabby-images/b3267/b326796aa0bcf0bf1b8935eb2250e78f60d1c808" alt=""
11.and条件查询:
data:image/s3,"s3://crabby-images/f3463/f34635a2ad5e567ce4809ba8ea968e8650ba1c10" alt=""
12.or条件查询:
data:image/s3,"s3://crabby-images/e5a12/e5a12a291b0245a01543e1d3cebff48b72d592f2" alt=""
13.修改数据:
data:image/s3,"s3://crabby-images/dd11f/dd11f09e0f88f607b1205d96a884b51dfbd89786" alt=""
14. 删除数据:
data:image/s3,"s3://crabby-images/75fd3/75fd35b0188ec67aaf66feec62b47a801f835d4b" alt=""
使用Java API对MongoDB进行访问
1.将下载之后的jar包导入并且创建工程之后,在新建立的工程之下创建MongoDBExample.java文件:
data:image/s3,"s3://crabby-images/4edf0/4edf058392793f3b9604373323e2623cea739cab" alt=""
2.代码:
data:image/s3,"s3://crabby-images/0f2a4/0f2a4024e557749568a37536153d97a3d4fd857f" alt=""
data:image/s3,"s3://crabby-images/3dc10/3dc10a70dcc68341b57c1cff4b338dae88ae2f50" alt=""
data:image/s3,"s3://crabby-images/35ddd/35dddfb7c02a01f4ffe9f7fc9a0ab3eca1f38db6" alt=""
data:image/s3,"s3://crabby-images/4b1ea/4b1eab8d1d2078ab7273f66f4267d77771a268ae" alt=""
3.结果:
data:image/s3,"s3://crabby-images/39d35/39d359793cb39a39b0e52a36d5cd880824c42cb0" alt=""
三.出现的问题及解决方案:
1.使用redis数据库的时候,需要注意键值对的选择,注意,使用中文的时候可能会导致发生数据错误。
2.使用MongoDB的时候,注意对应的版本号,切换集合的时候,需要注意集合是否存在。
四.总结:
redis是NOSQL,即非关系型数据库,也是缓存数据库,即将数据存储在缓存中,缓存的读取速度快,能够大大的提高运行效率,但是保存时间有限。MongoDB是非关系型数据库(nosql ),属于文档型数据库。文档是MongoDB中数据的基本单元,类似关系数据库的行,多个键值对有序地放置在一起便是文档,语法有点类似javascript面向对象的查询语言,它是一个面向集合的,模式自由的文档型数据库。