参考资料为:

教材代码-林子雨编著《大数据基础编程、实验和案例教程(第2版)》教材所有章节代码_厦大数据库实验室博客

1.实验学时

4学时

2.实验目的

  • 熟悉Redis系统的安装和应用
  • 熟悉MongoDB的安装和使用
  • 掌握MongoDB编程实践

3.实验内容

(一)完成Redis的安装和使用。完成数据库的插入,删除,以及查询。

先下载到对应的文件夹:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库

文件夹改名:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_02

文件夹权限赋予:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_03

输入命令安装redis

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_04

安装成功。

打开redis服务器:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据_05

建立新终端然后输入命令进入redis客户端:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_06

使用键值对:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_07

创建三个表:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据_08

开始插入数据:

成功插入数据“算法”

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_09

修改数据:这里中文识别有点问题

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_10

成功修改为“编译原理”

删除数据:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_11

这里中文显示有问题。

成功删除刚刚设置的“编译原理名字”

这里的数据库编译方式是:表名字:行名字:列名字

(二)MongoDB的安装和使用。完成MongoDB的基本的shell命令。

使用软件源安装MongoDB

查找下载对应软件包

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_12

创建MongoDB文件列表

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_13

安装MongoDB

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_14

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_15

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_16

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_17

安装成功。

启动MongoDB成功

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_18

开始使用shell命令:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_19

常见命令:

展现数据库、使用数据库、创建集合

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_20

切换数据库(school)

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_21

插入数据:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_22

如果是save,_id相同,则会更新数据。insert会插入数据

查找数据:

一般来说,查找数据的格式为db.yourCollection.find(criteria,filterDisplay);

如果查询条件为空,可以使用{}作为占位符

查询所有记录:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_23

查询指定记录(数据)

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_24

查询指定列、sname、sage数据

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_25

and条件查询:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_26

or条件查询

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_27

修改数据:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_28

删除数据:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_29

删除集合:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据_30

(三)使用Java API对MongoDB进行访问。

传输文件之后,打开eclipse:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据_31

将下载之后的jar包导入并且创建工程之后,在新建立的工程之下创建MongoDBExample.java文件

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_32

然后接入代码:下面为java代码

import java.util.ArrayList;
import java.util.List; 
import org.bson.Document;
import com.mongodb.MongoClient;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.Filters; 
public class TestMongoDB {
    /**
     * @param args
     */
    public static void main(String[] args) {
//      insert();//插入数据。执行插入时,可将其他三句函数调用语句注释,下同
        find(); //查找数据
//      update();//更新数据
//      delete();//删除数据
    }
    /**
     * 返回指定数据库中的指定集合
     * @param dbname 数据库名
     * @param collectionname 集合名
     * @return
     */
    //MongoDB无需预定义数据库和集合,在使用的时候会自动创建
    public static MongoCollection<Document> getCollection(String dbname,String collectionname){
        //实例化一个mongo客户端,服务器地址:localhost(本地),端口号:27017
        MongoClient  mongoClient=new MongoClient("localhost",27017);
        //实例化一个mongo数据库
        MongoDatabase mongoDatabase = mongoClient.getDatabase(dbname);
        //获取数据库中某个集合
        MongoCollection<Document> collection = mongoDatabase.getCollection(collectionname);
        return collection;
    }
    /**
     * 插入数据
     */
    public static void insert(){
        try{
            //连接MongoDB,指定连接数据库名,指定连接表名。
            MongoCollection<Document> collection= getCollection("School","student");    //数据库名:School 集合名:student
            //实例化一个文档,文档内容为{sname:'Mary',sage:25},如果还有其他字段,可以继续追加append
            Document doc1=new Document("sname","Mary").append("sage", 25);
            //实例化一个文档,文档内容为{sname:'Bob',sage:20}
            Document doc2=new Document("sname","Bob").append("sage", 20);
            List<Document> documents = new ArrayList<Document>(); 
            //将doc1、doc2加入到documents列表中
            documents.add(doc1); 
            documents.add(doc2); 
            //将documents插入集合
            collection.insertMany(documents);  
            System.out.println("插入成功"); 
        }catch(Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );
        }
    }
    /**
     * 查询数据
     */
    public static void find(){
        try{
            MongoCollection<Document> collection = getCollection("School","student");  //数据库名:School 集合名:student
            //通过游标遍历检索出的文档集合 
//          MongoCursor<Document>  cursor= collection.find(new Document("sname","Mary")). projection(new Document("sname",1).append("sage",1).append("_id", 0)).iterator();   //find查询条件:sname='Mary'。projection筛选:显示sname和sage,不显示_id(_id默认会显示)
            //查询所有数据
            MongoCursor<Document>  cursor= collection.find().iterator();
            while(cursor.hasNext()){
                System.out.println(cursor.next().toJson());
            }
        }catch(Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );
        }
    }
    /**
     * 更新数据
     */
    public static void update(){
        try{
            MongoCollection<Document> collection = getCollection("School","student");  //数据库名:School 集合名:student
             //更新文档,将文档中sname='Mary'的文档修改为sage=22   
             collection.updateMany(Filters.eq("sname", "Mary"), new Document("$set",new Document("sage",22)));  
             System.out.println("更新成功!");
        }catch(Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );
        }
    }
    /**
     * 删除数据
     */
    public static void delete(){
        try{
            MongoCollection<Document> collection = getCollection("School","student");  //数据库名:School 集合名:student
                //删除符合条件的第一个文档  
            collection.deleteOne(Filters.eq("sname", "Bob"));  
            //删除所有符合条件的文档  
            //collection.deleteMany (Filters.eq("sname", "Bob"));
            System.out.println("删除成功!");
        }catch(Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );
        }
    }
}

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_mongodb_33

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_System_34

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_nosql_35

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据_36

得到结果:

nosql数据库原理与应用教材PDF熊江 nosql数据库实验报告_数据库_37

4.思考题

(一)Redis和传统的Mysql数据库的区别在哪里?

1.mysql是关系型数据库,主要用于存放持久化数据,将数据存储在硬盘中,读取速度较慢。

2.redis是NOSQL,即非关系型数据库,也是缓存数据库,即将数据存储在缓存中,缓存的读取速度快,能够大大的提高运行效率,但是保存时间有限

(二)MongoDB有哪些特点,和Mysql数据库的区别在哪里?

MongoDB是非关系型数据库(nosql ),属于文档型数据库。文档是MongoDB中数据的基本单元,类似关系数据库的行,多个键值对有序地放置在一起便是文档,语法有点类似javascript面向对象的查询语言,它是一个面向集合的,模式自由的文档型数据库。

MongoDB是非关系型数据库,而Mysql是关系型数据库。

MongoDB存储方式是内存虚拟+持久化,Mysql有不同的引擎对应着不同的存储方式。

MongoDB的成熟度比较低,,但是Mysql数据库的成熟度比较高。

MongoDB的优势在于他的速度、高拓展性、存储形式。Mysql优势在于他的广泛程度,成熟的体系。

5.实验结论或体会

1.使用redis数据库的时候,需要注意键值对的选择,注意,使用中文的时候可能会导致发生数据错误。

2.使用MongoDB的时候,注意对应的版本号,切换集合的时候,需要注意集合是否存在。

3.eclipse中编写java程序的时候,需要注意jar包的导入。