【MySQL】数据库基础操作

在这里插入图片描述

  • 👑专栏内容:MySQL
  • ⛪个人主页:子夜的星的主页
  • 💕座右铭:前路未远,步履不停

目录

  • 一、数据库操作
    • 1、创建数据库
    • 2、查看所有数据库
    • 3、选定指定数据库
    • 4、删除数据库
  • 二、数据表操作
    • 1、创建数据表
    • 2、查看所有表
    • 3、查看指定表的结构
    • 4、删除表
  • 三、增删改查
    • 1、新增
      • 指定列插入
      • 插入多个记录
      • 两者区别
    • 2、查询
      • 全列查询
      • 指定列查询
      • 查询字段为表达式
      • 查询时去重
      • 排序查询
      • 条件查询
    • 3、修改
      • 多列修改
      • 排序修改
    • 4、删除


一、数据库操作

1、创建数据库

create database  数据库名;
  • create,database 相当于关键字
  • SQL 关键字不区分大小写
  • 数据库名不能重复
create database 数据库名 character set utf8;
  • 创建数据库的时候,指定字符集

2、查看所有数据库

show databases;

3、选定指定数据库

use 数据库名;

一旦选定某个指定数据库,后续操作,就都是针对该数据库展开。

4、删除数据库

drop database 数据库名;

注意:drop操作是非常危险的,一旦删掉数据库,数据库中的所有数据都没了。

二、数据表操作

1、创建数据表

create table 表名(列名 类型 , 列名 类型.....);

重点了解如下数据类型:
intbigintvarchardoubledecimaldatetime
创建表的时候,需要把表的类型确定好,后续插入的数据也要遵循当前类型。

create table product(
  name varchar(30),
  price int ,
  inventory int , 
  description varchar(30)
);

2、查看所有表

show tables;

3、查看指定表的结构

desc 表名;

image.png
Field:字段。表示一行里面有几列
Type:每一列的类型
NULL:该列是否允许为空,YES 就是允许为空(不填)
Default:不填的时候的默认值
Extra:额外的补充信息

4、删除表

drop table 表名;

删除表,相当于删除整个表的所有数据。也是一个危险的操作。

三、增删改查

1、新增

insert into 表名 values (值,值,值...);
  • SQL 中 都行。
  • 大多数没有字符类型的编程语言,都是允许单引号和双引号来表示字符串,并且单双引号的效果是等价的。
  • 注意:要想插入中文,必须在创建数据库的时候,指定 charset utf8

指定列插入

insert into book(name) values ('三国演义'); 

使用 ()来标识当前要针对那些列进行插入,多个列名之间可以用,来分割。

插入多个记录

insert into book values (10,'a'),(12,'b')....;

两者区别

一次插入三条记录和分三次插入,每次插入一条记录有什么区别???

MySQL 是一个客户端服务器结构的程序。



每次执行SQL都涉及到了客户端和MySQL服务器之间的通信!所以,每一次的网络交互都有成本,所以多行数据插入是优于单行多次插入的!!

2、查询

全列查询

select *from 表名;
  • * 是通配符,可以代指任意的列。


select * 一个非常危险的操作!
因为select * 会查询所有的数据。如果查询的数据非常非常多,那么就会导致这个服务器一瞬间,硬盘的带宽和网卡的带宽都被吃满了。

指定列查询

手动指定查询某一列或者某几列。

select 列名,列名....from 表名;
select name,author from book;

查询字段为表达式

查询的同时,可以进行计算。

select name,price-30 from book;

MySQL是一个客户端 服务器 结构的程序!!我们看到的客户端显示的结果是一个“临时表”,select 操作不管怎么写,都不会影响到数据库服务器硬盘上存储的原始数据。
查询结构的列名和表达式是一致的,不利于用户阅读。所以,我们在查询的时候,可以给表达式指定别名。

select name,price-30 as '价钱-30' from book;

查询时去重

把重复的行去掉,只保留一份。

select distinct 列名 from 表名;

排序查询

对查询到的结果进行排序。MySQL是一个客户端 服务器 结构的程序,我们看到的客户端显示的结果是一个“临时表”。对于数据库服务器上的原始的数据没有任何的顺序上的影响。

-- 升序排序(asc可以不写)
select 列名 from 表名 order by 列名 asc;
-- 降序排序
select 列名 from 表名 order by 列名 desc;
-- 多列排序(多列排序有先后顺序)
-- 先排前面的。前面的一样再排后面的
select 列名 from 表名 order by 列名,列名....asc;

image.png
默认为升序排序,如果想要降序排序,就在列名后面加上 desc

select 列名 from 表名 order by 列名 desc;

image.png
如果SQL中,没有指定 order by,此时我们的代码中就不应该依赖结果临时表的顺序!MySQL并不承诺,这个不带order by的查询结果是带有一定顺序的。

条件查询

查询的同时,制定一个筛选条件,把符合条件的结果保留,不符合的就剔除掉。
比较运算符

运算符解释
>,>=,<,<=大于,大于等于,小于,小于等于
=等于,NULL 不安全,例如 NULL = NULL 的结果是 NULL
<=>等于,NULL 安全,例如 NULL <=> NULL 的结果是 TRUE(1)
!=,<>不等于
between a0 and a1范围匹配,[a0, a1],如果 a0 <= value <= a1,返回 TRUE(1)
in(option,…)如果是 option 中的任意一个,返回 TRUE(1)
IS NULL是NULL
is not NULL不是NULL
like模糊匹配。% 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字

逻辑运算符

运算符解释
and多个条件必须都为 TRUE(1),结果才是 TRUE(1)
or任意一个条件为 TRUE(1), 结果为 TRUE(1)
not条件为 TRUE(1),结果为 FALSE(0)
  • 有些列可以不填,不填就相当于 NULL
  • where 条件可以使用表达式,但不能使用别名。
  • and 的优先级高于 or,在同时使用时,需要使用小括号 () 包裹优先执行的部分。
select name,price from book where price < 89;

image.png
理解查询语句执行的过程:

  1. 服务器需要先遍历表中的每一个记录
  2. 针对当前记录,带入条件,看是否成立
  3. 如果条件成立,则将这一结果加入结果集,返回给客户端。否则,跳过该结构。
-- 查询英语不及格的同学及英语成绩 ( < 60 )
select name, english from exam_result where english < 60;
-- 查询语文成绩好于英语成绩的同学
select name, chinese, english from exam_result where chinese > english;
-- 查询总分在 200 分以下的同学
select name, chinese + math + english as total from exam_result where chinese + math + english < 200;
-- 查询语文成绩大于80分,且英语成绩大于80分的同学
select * from exam_result where chinese > 80 and english > 80;
-- 查询语文成绩大于80分,或英语成绩大于80分的同学
select * from exam_result where chinese > 80 or english > 80;
-- 观察and 和 OR 的优先级:
select * from exam_result where chinese > 80 or math>70 and english > 70;
select * from exam_result where (chinese > 80 or math>70) and english > 70;
-- 查询语文成绩在 [80, 90] 分的同学及语文成绩
select name, chinese from exam_result where chinese between 80 and 90;
-- 使用 and 也可以实现
select name, chinese from exam_result where chinese >= 80 and chinese <= 90;
-- 查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩
select name, math from exam_result where math IN (58, 59, 98, 99);
-- 使用 OR 也可以实现
select name, math from exam_result where math = 58 OR math = 59 OR math = 98 OR math = 99;
-- % 匹配任意多个(包括 0 个)字符
select name from exam_result where name like '孙%';-- 匹配到孙悟空、孙权
-- _ 匹配严格的一个任意字符
select name from exam_result where name like '孙_';-- 匹配到孙权
-- 查询 qq_mail 已知的同学姓名
select name, qq_mail from student where qq_mail is not null;
-- 查询 qq_mail 未知的同学姓名
select name, qq_mail from student where qq_mail IS NULL;

3、修改

update 表名 set 列名 =where 条件;

进行修改,要明确一些重要的信息。

  • 改那个表?
  • 改这个表的那个列?
  • 改这个表的那写行?
update book set price = 80 where name = '1984';
-- 把book表中的price列中1984这一行改成80
-- 这里面的 = 和上面的查询不一样,是赋值而不是相等

select 支持的各种条件,对于 update 来说也是同样生效的。
update 可以理解为先查后改。

update book set price = 0;

update 后面不加其他操作会出现上面??
会把所有的数据都修改掉!!非常非常非常危险!!
【注意】

  • update 是一个非常危险的操作。

多列修改

update 表名 set 列名 =,列名 =where 条件;
update book set price = 80, class = '西方小说' where name = '1984';

排序修改

update 表名 set 列名 = 列名 + xxx  order by 排序条件 ;
update book set price = price - 20 order by price limit 3;
-- 把price最低是三位再减20

4、删除

delete from 表名 where 条件;
-- 直接删除符合条件的行
delete from book where name = '了不起的盖茨比';

删除是按行来删除的,无法直接删除某些列。
要想删除列,可以通过 update 来更新为 null
select 支持的各种条件,对于 delete 来说也是同样生效的。
如果在 delete的时候没有指定条件,就会把所有的都删除。效果和删表差不多了。

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

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

相关文章

debian 设置系统默认以命令行方式启动,关闭x windows

debian 设置系统默认以命令行方式启动&#xff0c;关闭x windows 2021-01-02 tech linux 设置 grub启动设置在/etc/default/grub中&#xff0c;打开 default grub 配置: $ sudo vim /etc/default/grub修改以下配置&#xff1a; 更新grub&#xff0c;设置多用户启动: …

为何百兆静态库能打进数兆的可执行文件?

第三方库是工程开发必不可少的部分&#xff0c;而第三方库可以是.a和.framework的静态库&#xff0c;也可以是.framework的动态库&#xff0c;其中静态库是最常用的方式。 静态库往往比较大&#xff0c;可在打包到可执行文件之后&#xff0c;对安装包大小的增加远远小于静态库本…

Linux 常见命令篇

history 获取执行的指令记录 语法格式: history [参数] 常用参数&#xff1a; -a 写入命令记录 -c 清空命令记录 -d 删除指定序号的命令记录 -n 读取命令记录 -r 读取命令记录到缓冲区 -s 将指定的命令添加到缓冲区 -w 将缓冲区信息写入到历史文件 history#获取最近的三条…

Python是个什么鬼?朋友靠它拿了5个offer

闺蜜乐乐&#xff0c;外院科班出身&#xff0c;手持专八和CATTI证书&#xff0c;没想到找工作时却碰了钉子… 半夜12点&#xff0c;乐乐跟我开启了吐槽模式&#xff1a; 拿到offer的都是小公司的翻译活儿&#xff0c;只能糊个口。稍微好点的平台要求可就多了&#xff0c;不仅语…

java计算下一个整10分钟时间点

最近工作上遇到需要固定在整10分钟一个周期调度某个任务&#xff0c;所以需要这样一个功能&#xff0c;记录下 package org.example;import com.google.gson.Gson; import org.apache.commons.lang3.time.DateUtils;import java.io.InputStream; import java.util.Calendar; i…

Hive内置表生成函数

Hive内置UDTF 1、UDF、UDAF、UDTF简介2、Hive内置UDTF 1、UDF、UDAF、UDTF简介 在Hive中&#xff0c;所有的运算符和用户定义函数&#xff0c;包括用户定义的和内置的&#xff0c;统称为UDF&#xff08;User-Defined Functions&#xff09;。如下图所示&#xff1a; UDF官方文档…

Springboot学生疫情管理系统-计算机毕设 附源码 25567

Springboot学生疫情管理系统的设计与实现 摘 要 随着互联网趋势的到来&#xff0c;各行各业都在考虑利用互联网将自己推广出去&#xff0c;最好方式就是建立自己的互联网系统&#xff0c;并对其进行维护和管理。在现实运用中&#xff0c;应用软件的工作规则和开发步骤&#xf…

Dubbo配置注册中心设置application的name使用驼峰命名法可能存在的隐藏启动异常问题

原创/朱季谦 首先&#xff0c;先提一个建议&#xff0c;在SpringBootDubbo项目中&#xff0c;Dubbo配置注册中心设置的application命名name的值&#xff0c;最好使用xxx-xxx-xxx这样格式的&#xff0c;避免随便使用驼峰命名。因为使用驼峰命名法&#xff0c;在Spring的IOC容器…

数据结构总复习

文章目录 线性表动态分配的顺序存储结构链式存储 线性表 动态分配的顺序存储结构 通过分析代码&#xff0c;我们发现&#xff0c;要注意什么&#xff1a; 要分清你的下标Insert 函数是可以用来没有元素的时候&#xff0c;增加元素的Init(或者Create )函数一般只用来分配空间…

Python中如何选择Web开发框架?

Python开发中Web框架可谓是百花齐放&#xff0c;各式各样的web框架层出不穷&#xff0c;那么对于需要进行Python开发的我们来说&#xff0c;如何选择web框架也就变成了一门学问了。本篇文章主要是介绍目前一些比较有特点受欢迎的Web框架&#xff0c;我们可以根据各个Web框架的特…

在线定制印刷系统源码/定制云印刷/个性印刷在线DIY定制商城系统/全站DIV+CSS 布局+手机、PC端

源码简介&#xff1a; 在线定制印刷系统源码/定制云印刷&#xff0c;它是个性印刷在线DIY定制商城系统&#xff0c;而且全站采用DIVCSS 布局&#xff0c;可以手机、PC端实时互通。 支持多种产品定制&#xff0c;包括但不限于水杯、雨伞、U盘、T恤、衬衫和四件套。独创的制作间…

Jenkins与Docker的自动化CI/CD流水线实践

Pipeline 有诸多优点&#xff0c;例如&#xff1a; 项目发布可视化&#xff0c;明确阶段&#xff0c;方便处理问题 一个Jenkins File文件管理整个项目生命周期 Jenkins File可以放到项目代码中版本管理 Jenkins管理界面 操作实例&#xff1a;Pipeline的简单使用 这里是比较…

电源控制系统架构(PCSA)之系统分区电压域

目录 4.1 电压域 4.1.1 系统逻辑 4.1.2 Always-On逻辑 4.1.3 处理器Clusters 4.1.4 图形处理器 4.1.5 其他功能 4.1.6 SoC分区示例 本章描述基于Arm组件的SoC划分为电压域和电源域。 所描述的选择并不详尽&#xff0c;只是可能性的一个子集。目的是描述基于Arm组件的SoC…

MySQL-04-InnoDB存储引擎锁和加锁分析

Latch一般称为闩锁&#xff08;轻量级锁&#xff09;&#xff0c;因为其要求锁定的时间必须非常短。在InnoDB存储引擎中&#xff0c;latch又分为mutex&#xff08;互斥量&#xff09;和rwlock&#xff08;读写锁&#xff09;。 Lock的对象是事务&#xff0c;用来锁定的是…

实验题【网关设置+VRRP+静态路由+OSPF】(H3C模拟器)

嘿&#xff0c;这里是目录&#xff01; ⭐ H3C模拟器资源链接1. 实验示意图2. 要求和考核目标3. 当前配置3.1 PC1、PC2、PC3、PC4和PC5配置3.2 SW配置3.2.1 SW2配置3.2.2 SW3配置3.2.3 SW4配置3.2.4 SW1配置 3.2. R配置3.2.1 R1配置3.2.2 R2配置 ⭐ H3C模拟器资源链接 H3C网络…

Windows下安装MySQL

几年前学习mycat中间件的时候在window机器上安装过MySql&#xff0c;但是由于电脑配置不高&#xff0c;同时打开Mysql服务&#xff0c;idea、SQlyog等软件非常卡&#xff0c;再加上SQLyog和MySQL版本不兼容导致登录不上&#xff0c;于是把它卸载了。最近做练习需要&#xff0c;…

Qt 软件调试(二)使用dump捕获崩溃信息

Qt应用程序异常崩溃该怎么办&#xff0c;生成dump文件再回溯分析&#xff0c;可以快速且准确的帮助我们定位到崩溃的点。那么&#xff0c;本章我们分享下如何在Qt中生成dump文件。 一、使用minudump捕获崩溃信息 #include <QCoreApplication> #include <QDir> #i…

用Python写一个浏览器集群框架

更多Python学习内容&#xff1a;ipengtao.com 在分布式爬虫和大规模数据采集的场景中&#xff0c;使用浏览器集群是一种有效的方式&#xff0c;可以提高数据采集的速度和效率。本文将介绍如何用Python编写一个简单但强大的浏览器集群框架&#xff0c;以应对需要使用多个浏览器实…

原生小程序图表

原生小程序使用图表 话不多说直接进入正题 官方文档: https://www.ucharts.cn/v2/#/ 下载文件 首先去gitee上把文件下载到自己的项目中 https://gitee.com/uCharts/uCharts 找到微信小程序和里面的组件 把里面src下的文件全部下载下来放入自己项目中 项目文件 新建文件…

使用Linux JumpServer堡垒机本地部署与远程访问

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;网络奇遇记、Cpolar杂谈 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 &#x1f4cb;前言一. 安装Jump server二. 本地访问jump server三. 安装 cpolar内网穿透软件四. 配…