Mysql基础 01 数据与sql

文章目录

  • 一、基本概念
  • 二、mysql的常用命令
  • 三、sql规范
  • 四、数据类型
  • 五、SQL语句

一、基本概念

数据库(database,DB):存储数据的仓库。

数据库管理系统软件(Database Management System,DBMS):是一种操作和管理数据库的大型软件。常见的DBMS有oracle、sql server、Mysql

数据库系统(Data Base System,DBS):有软件、数据库和数据管理员组成。

二、mysql的常用命令

1、登录:mysql -h 服务器IP -P 端口号 -u 用户名 -p 密码 --prompt 命令提示符 --delimiter 指定分隔符
  例:mysql -uroot -p

2、退出:quit exit \q

三、sql规范

SQL是专门为数据库而建立的操作命令集,现在几乎所有的数据库均支持sql

1、SQL语句不区分大小写,但字符串常量区分大小写。建议命令大写,表明库名小写。

2、SQL语句课单行或多行写,以分号“;”结尾。

3、可用空格和缩进来提高语句的可读性。

4、注释:单行注释:--   多行注释:/* */

5、SQL语句可以折行操作。

四、数据类型

数值类型
在这里插入图片描述


日期和时间类型
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
在这里插入图片描述


字符串类型
在这里插入图片描述


此外,还有一个BIT类型,占一个二进制位长度,可以用来表示布尔类型。

五、SQL语句

1、显示当前的日期和时间:select now();

2、查看所有数据库:show databases;

3、创建数据库(在磁盘上创建一个对应的文件夹):create database [if not exists] db_name [character set xxx]
  注:①写if not exists,当创建的数据库已存在,也不会报错。
    ②character set xxx表示创建xxx字符集。
  例:create database s3;

4、显示警告信息:show warnings;

5、显示数据库s3的创建信息:show create database s3

6、删除数据库s4:drop database [if exists] s4;

7、修改数据库字符集为gbk(默认为utf8):alter database s3 character set gbk;

8、切换数据库到s4:use s4;

9、查看当前使用的数据库:select database();

10、创建表(类似一个excel表):
create table tab_name(
  field1 type [约束条件],
  field2 type [约束条件],
  …
  fieldn type [约束条件]
)

约束:
  primary key (非空且唯一) :能够唯一区分出当前记录的字段称为主键。主键字段必须是数字类型。一张表只有一个主键。
  unique
  not null 该字段值非空
  auto_increment 字段的值自增1
  foreign key 外键约束

例:

CREATE TABLE employee(
    id TINYINT PRIMARY KEY auto_increment,
    name VARCHAR(4),
    gender TINYINT(1),
    age INT,
    department VARCHAR(20),
    salary DOUBLE(7,2)
);

注:TINYINT(1)表示1个位宽。VARCHAR(4)表示4个字符。DOUBLE(7,2)表示总共7位数字,其中2位为小数。

11、查看当前库下的表名:show tables;

12、查看employee表结构:desc employee; 或 show columns from employee;

13、查看表的创建信息:show create table employee;

14、添加一个表字段,例:
alter table employee add is_married tinyint(1);
alter table employee add entry_date not null;
alter table employee add A INT, add B VARCHAR(10);

15、删除表字段:alter table emplyee drop A,drop entry_date;

16、修改一列类型:alter table tab_name modify 列名 类型 [完整性约束条件][first|after 字段名];
其中first表示排字段第一个,after表示排某个字段后面。
例:alter table employee modify age smallint not null default 18 alter id;

17、修改列名:alter table tab_name change [column] 列名 新列名 类型 [完整性约束条件][first|after 字段名];
例:alter table employee change department depart varchar(20) after salary;

18、修改表名:rename table 表名 to 新表名;

19、删除表:drop table 表名;

20、插入一条表记录:
①insert [into] tab_name (field1,filed2,…) values (value1,value2,…);
②insert [into] tab_name values (所有字段值);
③insert [into] tab_name set 字段名=值;

21、插入多条表记录:
insert [into] tab_name (field1,filed2,…) values
  (value1,value2,…),
  (value3,value4,…);

22、修改表记录:
update tab_name set field1=value1,field2=value2,…[where 语句];
注:没有WHERE子句,则更新所有的行。
例:update employee set salary=salary+200 where name=“xixi”;

23、删除表纪录:如果不跟where语句则删除整张表中的数据。delete语句只能删除表记录,不能删除表结构,想要一同删除表记录和表结构,用drop。delete语句是逐条删除记录,而TRUNCATE也可以删除表中的所有数据,它是首先摧毁表,再新建表。TRUNCATE删除的数据不能在事务中恢复。
delete from tab_name [where …];
truncate table tab_name;

24、查询表的所有记录:SELECT * FROM tab_name;

25、查询表的某些字段的所有记录:SELECT field1,filed2 … FROM tab_name;

26、查询表的所有不重复的记录:select [distinct] *|field1,field2,… from tab_name;

27、select 也可以使用表达式,并且可以使用: 字段 as 别名或者:字段 别名:
select name as na,age+10 from emp;

28、select语句使用where子句,进行过滤查询。例:
select name na,age+10 as a from emp where age>=20;
如果字段值为null,使用 is,而不是 =。
例:select * from emp where id=3 and gender is null;

where字句中可以使用:
  比较运算符:
  > < >= <= <> !=
  between 80 and 100 值在10到20之间
  in(80,90,100) 值是10或20或30
  like ‘xi%’

  pattern可以是%或者_,
  如果是%则表示任意多字符,此例如唐僧,唐国强
  如果是_则表示一个字符唐_,只有唐僧符合。两个_则表示两个字符:__

在多个条件直接可以使用逻辑运算符 and or not

29、select语句使用Order by 指定排序的列,排序的列即可是表中的列名,也可以是select 语句后指定的别名。
select *|field1,field2… from tab_name order by field [Asc|Desc]
Asc 升序、Desc 降序,其中asc为默认值 ORDER BY 子句应位于SELECT语句的结尾。

30、使用正则表达式查询,例:
select * from order_menu where product_name regexp “香蕉$”;

31、Mysql在执行sql语句时的执行顺序:from  where  select  group by  having  order by  limit
having和where作用相同,只是执行顺序不同。
分析:
select JS as JS成绩 from ExamResult where JS成绩 >70; ---- 不成功
select JS as JS成绩 from ExamResult having JS成绩 >90; — 成功

32、group by 分组查询:
select * from order_menu group by 4,5;
以第4和5列为基准分组,相同的合并,只显示每组的第一行。也可以写字段名:
select * from order_menu group by born_date,class;
注:禁用 ONLY_FULL_GROUP_BY 模式:SET sql_mode = ‘’;

33、使用聚合函数,例:
select class,sum(price) from order_menu group by class;

  count(列名):统计行的个数。注意:count(*)统计所有行,而 count(字段)用来统计某一列中非 NULL 的行数。

  SUM(列名):统计满足条件的行的内容和

  AVG(列名):会计算列中所有非 NULL 值的平均值

  Max()、Min():最大、最小值

34、加having过滤行
select class,sum(price) from order_menu group by class having sum(price)>200;

35、ifnull(price,0):如果price的值为null,则设置为0
select class,min(ifnull(price,0)) from order_menu group by class;

36、limit:显示行数
select * from order_menu limit 3; 显示前3行
select * from order_menu limit 3,3; 跳过前3行,显示接下来的3行。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

5G NR:各物理信道的DMRS配置

DMRS简介 在5G中&#xff0c;DMRS&#xff08;DeModulation Reference Signal&#xff09;广泛存在于各个重要的物理信道当中&#xff0c;如下行的PBCH&#xff0c;PDCCH和PDSCH&#xff0c;以及上行的PUCCH和PUSCH。其最为重要的作用就是相干解调&#xff08;Coherence Demodu…

从零开始:利用Portainer CE和cpolar搭建NextCloud私有云存储

文章目录 前言1. 在PortainerCE中创建NextCloud容器2. 公网远程访问本地NextCloud容器2.1 内网穿透工具安装3.2 创建远程连接公网地址 3. 固定NextCloud私有云盘公网地址 前言 本文将介绍如何在本地利用Portainer CE的可视化界面创建NextCloud私有云盘容器&#xff0c;并通过c…

第三十七章 Vue之编程式导航及跳转传参

目录 一、编程式导航跳转方式 1.1. path 路径跳转 1.1.1. 使用方式 1.1.2. 完整代码 1.1.2.1. main.js 1.1.2.2. App.vue 1.1.2.3. index.js 1.1.2.4. Home.vue 1.1.2.5. Search.vue 1.2. name 命名路由跳转 1.2.1. 使用方式 1.2.2. 完整代码 1.2.2.1. main.js 1…

人工智能(AI)和机器学习(ML)技术学习流程

目录 人工智能(AI)和机器学习(ML)技术 自然语言处理(NLP): Word2Vec: Seq2Seq(Sequence-to-Sequence): Transformer: 范式、架构和自注意力: 多头注意力: 预训练、微调、提示工程和模型压缩: 上下文学习、思维链、全量微调、量化、剪枝: 思维树、思维…

升级改进策略:鸡只图像分割

鸡只图像分割系统源码&#xff06;数据集分享 [yolov8-seg-rtdetr&#xff06;yolov8-seg-p2等50全套改进创新点发刊_一键训练教程_Web前端展示] 1.研究背景与意义 项目参考ILSVRC ImageNet Large Scale Visual Recognition Challenge 项目来源AAAI Global Al lnnovation C…

1.62亿元!812个项目立项!上海市2024年度“科技创新行动计划”自然科学基金项目立项

本期精选SCI&EI ●IEEE 1区TOP 计算机类&#xff08;含CCF&#xff09;&#xff1b; ●EI快刊&#xff1a;最快1周录用&#xff01; 知网(CNKI)、谷歌学术期刊 ●7天录用-检索&#xff08;100%录用&#xff09;&#xff0c;1周上线&#xff1b; 免费稿件评估 免费匹配期…

软件设计师下午题UML15分

一、涉及到的图及对应关系 二、例题 1.用例图和类图的例题 解析及答案 2.状态图和类图的例题 3.通信图和类图例题 例题

如何找到养生生活视频素材?推荐几个优秀网站

今天&#xff0c;我们来聊一个实用的话题&#xff0c;那就是如何找到优质的养生视频素材。作为自媒体创作者&#xff0c;高质量的视频素材对内容制作至关重要。不论你是刚入行的新手&#xff0c;还是已经积累了一定粉丝的大V&#xff0c;找到合适的养生视频素材都能帮助你更好地…

书生大模型第四期闯关任务与笔记

书生大模型第四期闯关任务与笔记 入门岛第一关 Linux闯关任务&#xff1a;完成SSH连接与端口映射并运行hello_world.py笔记与过程SSH端口映射linux文件管理命令linux进程管理命令 第二关 Python闯关任务&#xff1a;Leetcode 383(笔记中提交代码与leetcode提交通过截图)闯关任务…

Zabbix 7 最新版本安装 Rocky Linux 8

前言 本实验主要在Rocky Linux 中安装Zabbix&#xff0c;其他centos8、Debian、Ubuntu、Alma Linux都可以安装&#xff0c;就是在中间件有点不同。Nginx就要配置一下&#xff0c;官网给的教程也算是很规范的&#xff0c;就是在MySQL上要自己安装&#xff0c;他没有告诉我们&am…

Odoo:免费开源的钢铁冶金行业ERP管理系统

文 / 开源智造 Odoo亚太金牌服务 简介 Odoo免费开源ERP集成计质量设备大宗原料采购&#xff0c;备件设材全生命周期&#xff0c;多业务模式货控销售&#xff0c;全要素追溯单品&#xff0c;无人值守计量物流&#xff0c;大宗贸易交易和精细化成本管理等方案&#xff1b;覆盖…

刷题强训(day05) -- 游游的you、腐烂的苹果、孩子们的游戏(圆圈中最后剩下的数)

目录 1、游游的you 1.1 题目 1.2 思路 1.3 代码实现 2、腐烂的苹果 2.1 题目 2.2 思路 2.3 代码实现 3、孩子们的游戏(圆圈中最后剩下的数) 3.1 题目 3.2 思路 3.3 代码实现 3.3.1 环形链表 ​编辑3.3.2 动态规划 ​编辑 1、游游的you 1.1 题目 1.2 思路 根据题…

Java | Leetcode Java题解之第546题移除盒子

题目&#xff1a; 题解&#xff1a; class Solution {int[][][] dp;public int removeBoxes(int[] boxes) {int length boxes.length;dp new int[length][length][length];return calculatePoints(boxes, 0, length - 1, 0);}public int calculatePoints(int[] boxes, int l…

精华帖分享|历史波动率和已实现波动率纠缠研究

本文来源于量化小论坛公共讨论区板块精华帖&#xff0c;作者为期权罗&#xff0c;发布于2023年11月24日。 以下为精华帖正文&#xff1a; 01 思路由来 波动率研究有很多学术化得研究成果&#xff0c;比较枯燥/难&#xff0c;最近结合波动率继续交易了段时间&#xff0c;一是开…

ssm088基于JAVA的汽车售票网站abo+vue(论文+源码)_kaic

毕 业 设 计&#xff08;论 文&#xff09; 题目&#xff1a;汽车售票网站的设计与实现 摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为…

LeetCode Hot100 49.字母异位词分组

题干&#xff1a; 思路&#xff1a; 输入的是一个字符串数组&#xff0c;输出是一个列表&#xff0c;首先我们需要通过遍历数组获得每一个字符串&#xff0c;我们想要判断获得的任意两个字符串是不是字母异位词&#xff0c;所以可以将获得的字符串排序&#xff08;转换为字符数…

金属箔电阻

6.金属箔电阻如何实现“高精度” 电阻的阻值会受到各种“应力”影响而发生改变&#xff0c;离开稳定性的高精度是没有意义的。 例如&#xff0c;电阻出厂时的精度时0.01%&#xff0c;为了实现精度付出了高昂的费用&#xff0c;但在几个月的存储或几百个小时的负载后阻值的变化…

地下水数值模拟、 地下水环评、Visual modflow Flex、Modflow

地下水数值模拟软件Visual modflow Flex实践技术应用 地下水数值模拟软件的应用&#xff0c;主要围绕的目前应用较为广泛的Visual Modflow Flex 6.1软件版本开展&#xff0c;结合具体应用场景&#xff0c;实例讲解软件的全流程应用过程&#xff0c;包括数据处理分析、数值模型…

Python 爬虫运行状态监控:进度、错误与完成情况

Python 爬虫运行状态监控&#xff1a;进度、错误与完成情况 在进行大规模数据爬取时&#xff0c;监控爬虫的运行状态至关重要。通过实时监控&#xff0c;可以了解爬虫的工作进度、出现的错误以及任务完成情况。这样可以及时发现并解决问题&#xff0c;确保数据抓取任务顺利进行…

Windows下mysql数据库备份策略

Windows下mysql的增量备份和全量备份&#xff0c;并利用schtasks设置定时任务执行bat脚本。 一、备份要求 序号 备份类型 备份频次 备份时间 1 增量备份 每周一-每周六各一次 18:00:00 2 全量备份 每周日一次 18:00:00 二、备份方法 2.1增量备份 2.1.1准备工作…