一起重新开始学大数据-MySQL篇-Day33-SQL、建库建表、增删查改、聚合函数等

本文主要是介绍一起重新开始学大数据-MySQL篇-Day33-SQL、建库建表、增删查改、聚合函数等,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一起重新开始学大数据-MySQL篇-(1)

在这里插入图片描述

什么是数据库

在这里插入图片描述

数据库是数据的仓库
与普通的数据仓库不同的是,数据库依据数据结构来组织数据,因为数据结构的存在,所以看到的数据时条理化的
数据库和普通文件系统的区别在于:数据库拥有数据结构,能都快速查找对应的数据
常说的XX数据库,其实就是XX数据库管理系统:数据库管理系统是一个软件,是数据库服务的体现

数据库分为关系型数据库和非关系型数据库:

.关系型:以行作为记录,列数相同
.非关系型:以列作为记录,行数随便

什么是关系型数据库

关系型数据库依据关系模型创建数据库
关系模型就是一对一,一对多,多对多等关系模型,关系模型就是存储格式是以行列组成的二维表格,所以一个关系型数据库就是由二维表之间的联系所组成的一个数据组织
关系型数据库可以很好的存储一些关系模型的数据,比如老师对应学生的数据(“多对多”),一本书对应多个作者(“一对多”),一个人对应一个身份证号码(“一对一”)

什么是非关系型数据库

由于关系型太大和复杂,所以一般使用“非关系型数据”来表示其他类型的数据库
非关系型的模型比如:
列模型:存储的数据是一列一列,关系型数据库以一行作为一个记录,列模型数据库以一列为一个记录
键值对模型:存储的数据是一个个键值对,比如name:lisi
文档类模型:以一个个文档来存储数据,类似于键值对

数据库创建流程

服务器->数据库->表(行列组成的二维表格)->行

lient操作服务器通过命令登录操作:

mysql -u用户名(默认root) -p密码

命令:

SQL语句:每个命令执行结束加分号结束
查询所有数据库:show databases;
切换数据库:use 库命名;
创建数据库:create database [IF NOT EXISTS] 库名;
删除数据库:drop database [IF EXISTS] 库名;
查询数据库创建:show 建库语句;
指定数据库采用的字符集:CHARACTER SET
注意:
不要修改mysql服务器的编码集,表的编码集默认和库一致

建表

格式:

create table [if exists] 表名(
字段1 数据类型 字段属性,
字段2 数据类型 字段属性,
...
字段N 数据类型 字段属性
)engine=引擎 default charset=编码集;

在这里插入图片描述

查看当前数据库:select database();
在这里插入图片描述

查看建表语句:show create table 表名;
在这里插入图片描述

查看表结构:desc 表名;
在这里插入图片描述

删除:drop table [if exists] 表名;
OVO不想再添加,懒得

字段属性:

not null:没给值数据为默认值(varchar默认值为空)
AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1
PRIMARY KEY关键字用于定义列为主键,您可以使用多列来定义主键,列间以逗号分隔
ENGINE设置存储引擎,CHARSET 设置编码
default null:没给值数据就是null
default 值:设置字段的默认值
----注意:主键不重复的列

修改表结构:alter table
修改表名:alter table 旧表名 to 新表名;
添加字段:alter table 表名 add 字段 字段数据类型 属性;
修改字段:alter table 表名 change 旧字段 新字段 数据类型 属性;
修改字段:alter table 表名 modify 字段 数据类型 属性;

注意:
change:修改所有(字段名,数据类型,属性)
modify:修改一部分(数据类型,属性)
修改数据类型时,varchar->int原数据会变为0

增删改查:字符串全部使用’'包起来

在这里插入图片描述

insert 增:

格式:

insert into 表名(字段) values(值),(值)...(值);

例如:

insert into stduent(name) values('zs');
insert into stduent(name) values('zs'),('ls');

在这里插入图片描述

delete 删

格式:

delete from 表名 where 子句;

在这里插入图片描述

update改

格式:

update 表名 set 字段1=值1,字段2=值2...字段N=值N where 子句;
在这里插入图片描述

select查

格式:

select 字段 from 表名 where 子句;

注意:

*表示所有字段

在这里插入图片描述

起别名,子句,分页,去重

在这里插入图片描述

as 起别名

格式:

字段 as 名称

注意:

as 也加可不加

举例:列别名

在这里插入图片描述

举例:表别名

在这里插入图片描述

子句:

> 大于<小于<= 小于等于>= 大于等=等于<>不等于

注意:sql 里 符号<> 与 != 的区别

<> 与!=都是不等于的意思,但是一般都是用<>来代表不等于,因为<>在任何SQL中都起作用,但是!=在sql2000中用到,则是语法错误,不兼容的

between  ...and...显示在某一区间的值(含头含尾)in(set)显示在in列表中的值,例:in(100,200)只能匹配100或200like '张_'模糊查询  使用% 和 _(%表示匹配所有 _匹配一个)Is null判断是否为空

and多个条件同时成立or多个条件任一成立not不成立,例:where not(expection>10000);

limit分页

格式:

语句 limit 开始下标,长度;

注意:

如果数据量不够,显示全部

例如:三条语句①②③

SELECT * FROM student LIMIT 0,10;
SELECT * FROM student LIMIT 2,5;
SELECT * FROM student LIMIT 0,50;

①从位置0开始查找十条数据
②从位置2开始查找五条数据
③从位置0开始查找五十条数据,虽然数据只有十二条(1010被删除了)但是不会报错,输出全部数据

在这里插入图片描述在这里插入图片描述在这里插入图片描述

去重

格式:

DISTINCT 字段1,字段2...字段N

注意:

字段不能在DISTINCT之前,只能在DISTINCT后面
DISTINCT之后有多个字段,按照所有字段进行去重

例子

student表数据
在这里插入图片描述
执行如下三条查询语句

SELECT name,DISTINCT age FROM student;
SELECT DISTINCT name FROM student;
SELECT DISTINCT name,age from student;

第一句

在这里插入图片描述
第二句:重复的zs被只剩一个了
在这里插入图片描述
第三句:zs出现了两个,因为姓名和年龄为整体,所以年龄有区别的zs不是重复的
在这里插入图片描述0

聚合函数

在这里插入图片描述

count(字段):求多少行数据
sum(字段):求和
avg(字段):平均数
max(字段):最大值
min(字段):最小值

注意:
varchar能比较大小,不能获取avg(没有任何意义)
如果值为Null不参与计算
sumavg字段的数据不是数值,结果都是0

例:

student表数据
在这里插入图片描述

count(字段):求多少行数据

SELECT count(*) FROM student;
SELECT count(age) from student;

在这里插入图片描述在这里插入图片描述

sum(字段):求和

SELECT sum(*) FROM student;		/*查询语句一报错,因为名字等参与不了求和*/
SELECT sum(age) from student;

语句一
在这里插入图片描述
语句二
在这里插入图片描述

avg(字段):平均数

SELECT avg(age) from student;

在这里插入图片描述

max(字段):最大值

语句①查询年龄最大值
语句②查询名字最大值(结果出来了),说明名字可以比较大小

SELECT max(age) from student;
SELECT max(name) from student;

在这里插入图片描述在这里插入图片描述

min(字段):最小值

语句①查询年龄最小值
语句②查询名字最小值(结果出来了),说明名字可以比较大小

SELECT min(age) from student;
SELECT min(name) from student;

在这里插入图片描述在这里插入图片描述

字段运算与拼接

在这里插入图片描述

字段进行算术运算

格式:

(字段 符号 字段)

例如:

select (name+age) from students;

注意:

字符串参与运算字符串为0参与运算

在这里插入图片描述

拼接:

格式①:

concat(str1,str2...)

例如:把name和age以-拼接显示

select concat(name,'-',age)from students;

在这里插入图片描述

格式②:

concat_WS(separator,str1,str2,...)

例如:把name和age以-拼接显示

SELECT concat_WS('-',name,age) from student;

在这里插入图片描述

注意:

SELECT concat_WS(id,name,age) from student;

在这里插入图片描述
出现如上结果表明这种格式concat_WS(separator,str1,str2,...)固定,第一位始终为分隔符
|
|
|
|
|

前面一部分使用的是Linux里MySQL的界面,后面使用的是Navicat Premium远程连接MySQL,因为Navicat Premium的可视化界面确实好用点

本人用的Navicat Premium

链接:https://pan.baidu.com/s/1CyFbz1JDlWEooVa5dLL-rg
提取码:q6lg

对应的激活工具(安装好Navicat Premium后先点击激活工具后运行程序)

链接:https://pan.baidu.com/s/1dS6UWM3N0sP6sTjsVRc9aw
提取码:dump

|
|
|
|
|
|

上一章-Linux篇-Day32-shell脚本(2)、时间、定时器、安装MySQL

下一章-MySQL篇-Day34-日期函数、计算、排序分组筛选、连表联查等

|
|
|

听说长按大拇指👍会发生神奇的事情呢!好像是下面的画面,听说点过的人🧑一个月内就找到了对象的💑💑💑,并且还中了大奖💴$$$,考试直接拿满分💯,颜值突然就提升了😎,虽然对你好像也不需要,是吧,吴彦祖🤵!

在这里插入图片描述在这里插入图片描述

在这里插入图片描述

这篇关于一起重新开始学大数据-MySQL篇-Day33-SQL、建库建表、增删查改、聚合函数等的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更