MySQL 第七天作业 nosql作业

作业一:string list hash结构中,每个至少完成5个命令,包含插入 修改 删除 查询,list 和hash还需要增加遍历的操作命令

1、 string类型数据的命令操作:

(1) 设置键值:

复制代码
set key1 redis

(2) 读取键值:

复制代码
get key1

(3) 数值类型自增1:

复制代码
incr key1

(4) 数值类型自减1:

复制代码
decr key1

(5) 查看值的长度:

复制代码
STRLEN key1

2、 list类型数据的命令操作:

(1)对列表city插入元素:Shanghai Suzhou Hangzhou

复制代码
LPUSH city Shanghai Suzhou Hangzhou

(2)将列表city里的头部的元素移除

复制代码
LPOP city

(3)将name列表的尾部元素移除到number列表的头部

复制代码
RPOPLPUSH name number

(4) 对一个已存在的列表插入新元素

复制代码
RPUSH name e

(5)查看list的值长度

复制代码
LLEN name

(1)设置一个hash表,order表里包括的键值信息有:id:1,customer_name:张三

复制代码
HMSET order id 1 customer_name "张三"

(2) 创建一个hash表,表里的键值批量插入

复制代码
HMSET order1 name n add a ip i

(3) 获取order对应的map的所有key

复制代码
HKEYS order

(4) 获取order对应的map的键值数量

复制代码
HLEN order

(5) 获取order表里的id值

复制代码
HGET order id

4、Keys相关的命令操作

(1) 查看key是否存在

复制代码
EXISTS key1

(2) 查找满足pattern的keys

复制代码
KEYS or*

(3) 查看key的超时时间

复制代码
TTL key1

(4) 遍历key

复制代码
KEYS * 

作业二:mongodb作业

1. 创建一个数据库 名字grade

复制代码
use grade

2. 数据库中创建一个集合名字 class

复制代码
db.createCollection("class")

3. 集合中插入若干数据

复制代码
db.class.insert([
{name:"小计",age:10,sex:'m',hobby:['draw','basketball','pingpong']},
{name:"小红",age:8,sex:'f',hobby:['draw','dance','pingpong']},
{name:"小明",age:11,sex:'m',hobby:['football','dance','sing']},
{name:"小张",age:13,sex:'f',hobby:['draw','dance','pingpong']},
{name:"小龙",age:6,sex:'f',hobby:['draw','football','sing']},
{name:"小李",age:7,sex:'m',hobby:['draw','dance','pingpong']},
{name:"小陈",age:5,sex:'f',hobby:['draw','dance','sing']},
{name:"小钱",age:3,sex:'m',hobby:['pingpong','dance','sing']},
{name:"小明",age:6,sex:'f',hobby:['draw','dance','pingpong']},
{name:"小米",age:12,sex:'m',hobby:['draw','dance','football']},
{name:"小小",age:14,sex:'f',hobby:['draw','basketball','football']},
{name:"小康",age:15,sex:'m',hobby:['draw','basketball','pingpong']}
])

4. 查找

查看班级所有人信息

复制代码
db.class.find()

查看班级中年龄为8岁的学生信息

复制代码
db.class.find({age:8})

查看年龄大于10岁的学生信息

复制代码
db.class.find({age:8})

查看年龄在 4---8岁之间的学生信息

复制代码
db.class.find({age:{$gte:4,$lte:8}})

找到年龄为6岁且为男生的学生

复制代码
db.class.find({age:6,sex:"m"})

找到年龄小于7岁或者大于10岁的学生

复制代码
db.class.find({$or:[{age:{$lte:7}},{age:{$gte:10}}]})

找到年龄是8岁或者11岁的学生

复制代码
db.class.find({age:{$in:[7,11]}})

找到兴趣爱好有两项的学生

复制代码
db.class.find({'hobby':{$size:2}})

找到兴趣爱好有draw的学生

复制代码
db.class.find({'hobby':'draw'})

找到既喜欢画画又喜欢跳舞的学生

复制代码
db.class.find({'hobby':{$all:['draw','dance']}})

统计爱好有三项的学生人数

复制代码
db.class.find({'hobby':{$size:3}}).count()

找出本班年龄第二大的学生

复制代码
db.class.find({}).sort({age:-1}).skip(1).limit(1)

查看学生的兴趣范围

复制代码
db.class.distinct('hobby')

将学生按年龄排序找到年龄最大的三个

复制代码
db.class.find({}).sort({age:-1}).limit(3)

删除所有 年级大于12或者小于4岁的学生

复制代码
db.class.remove({$or:[{age:{$lt:4}},{age:{$gt:12}}]})

5. 增加、更新、删除、统计

将小红的年龄变为8岁 兴趣爱好变为 跳舞 画画

复制代码
db.class.update({'name':'小红'},{$set:{'age':8,'hobby':['dance','draw',]}})

追加小明兴趣爱好 打篮球

复制代码
db.class.update({'name':'小明'},{$push:{'hobby':'basketball'}})

小李兴趣爱好增加 吹牛 打篮球

复制代码
db.class.update({'name':'小李'},{$pushAll:{'hobby':['basketball','computer']}})

小李增加爱好,跑步和唱歌,但是不要和以前的重复

复制代码
db.class.update({'name':'小李'},{$addToSet:{'hobby':{$each:['run','sing']}}})

该班所有同学年龄加1

复制代码
db.class.update({},{$inc:{age:1}},false,true)

删除小明的sex属性

复制代码
db.class.update({name:'小明'},{$unset:{sex:0}})

删除小李兴趣中的第一项

复制代码
db.class.update({name:'小李'},{$pop:{hobby:-1}})

将小红兴趣中的画画爱好删除

复制代码
db.class.update({name:'小红'},{$pull:{hobby:'draw'}})

6.增加分数域

按照性别分组统计每组人数

复制代码
db.class.aggregate({$group:{_id:'$sex',num:{$sum:1}}})

按照姓名分组,过滤出有重名的同学

复制代码
db.class.aggregate([{$group:{_id:'$name',num:{$sum:1}}},{$match:{num:{$gt:1}}}])

统计每名男生的语文成绩

复制代码
db.class.aggregate([{$match:{sex:'m'}},{$project:{_id:0,name:1,'score.chinese':1}}])

将女生按照英语分数降序排列

复制代码
db.class.aggregate([{$match:{sex:'f'}},{$sort:{'score.english':-1}}])
相关推荐
Smile丶凉轩3 小时前
Qt 界面优化(绘图)
开发语言·数据库·c++·qt
昔柯的修炼日记4 小时前
使用 Navicat 将 Excel 导入数据库
数据库
进击的雷神6 小时前
数据库知识全面考查:从基础概念到实战应用
jvm·数据库·oracle
Le_ee7 小时前
sqli-labs靶场第七关——文件导出注入
数据库·sql·网络安全·php·sql注入·sqli—labs
dddaidai1237 小时前
分布式ID和分布式锁
redis·分布式·mysql·zookeeper·etcd
不知几秋7 小时前
Maven
java·数据库·maven
政沅同学7 小时前
数据库实验报告 SQL SERVER 2008的基本操作 1
数据库
lyw2056197 小时前
MySQL八股(自用)
数据库·mysql
MMMMMMMMMMemory8 小时前
pgsql14自动创建表分区
数据库·pgsql
文牧之8 小时前
PostgreSQL 配置设置函数
运维·数据库·postgresql