MySql基础(一)--最详细基础入门,看完就懂啦(辛苦整理,想要宝宝的赞和关注嘻嘻)

前言

希望你向太阳一样,有起有落,不失光彩~

一、数据库概述

1. 什么是数据库

数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。

 2.数据库管理系统

数据库管理系统(DataBase Managerment System, DBMS): 指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据。

 3.数据库的特点

1. 持久化存储数据的。其实数据库就是一个文件系统 
2. 方便存储和管理数据
    存储数据有一定的格式
    行和列的格式,当前表格看待就可以了
3. 使用了统一的方式操作数据库 
    使用图形界面的形式查看数据
    使用sql语言进行查看或管理数据

 4.常见的数据库

关系型数据库描述
MySQL开源免费的数据库,小型的数据库,已经被 Oracle 收购了。MySQL6.x 版本也开始收费。
Oracle收费的大型数据库,Oracle 公司的产品
DB2IBM 公司的数据库产品,收费的。常应用在银行系统中。
SQL ServerMicroSoft 公司收费的中型的数据库。C#、.net 等语言常使用。
SQLite嵌入式的小型数据库,应用在手机端,如:Android。
OceanBase阿里的大型数据库,性能已经超过Oracle全球第一
非关系型数据库(NoSQL)描述
MongoDBMongoDB最流行的文档型数据库
Redis基于内存的键值型数据库通过 Key-Value 键值的方式来存储数据

 5. MySQL服务启动和关闭

MySQL服务启动:

  1. cmd--> services.msc 打开服务的窗口--> MySQL服务启动

  2. 使用管理员打开cmd    net start mysql: 启动MySQL的服务

MySQL服务关闭:

  1. cmd--> services.msc 打开服务的窗口--> MySQL服务关闭

  2. 使用管理员打开cmd    net stop mysql: 关闭MySQL的服务

6.MySQL登录和退出

MySQL登录:

* 本地登录
     mysql -u用户名 -p密码 
    
* 指定ip登录
     mysql -h主机地址 -u用户名 -p密码

 MySQL退出:

1. exit
2. quit

二、 SQL概述

1. 什么是SQL

结构化查询语言(Structured Query Language)简称SQL,SQL语句就是对数据库进行操作的一种语言。

SQL是一套标准,所有的数据库厂商都实现了此标准;但是各自厂商在此标准上增加了特有的语句,这部分内容我们称为方言

2. SQL通用语法

3. 1. SQL 语句可以单行或多行书写,以分号结尾。
  select * from stu;
  select 
      *
  FROM
      stu;
2. 可使用空格和缩进来增强语句的可读性。
3. MySQL 数据库的 SQL 语句不区分大小写(仅此于win系统),关键字建议使用大写。
    1). 库名 表名 字段 别名 建议写小写
    2). 关键字建议大写: SHOW DATABASES CREATE
4. 3 种注释
    * 单行注释: -- 注释内容(这种方式是通用的) 或 # 注释内容(mysql 特有) 
    * 多行注释: /* 注释 */

3. SQL语句的分类

分类说明
DDL(Data Definition Language)数据定义语言定义数据库对象: 数据库,表,列等.关键字:create, drop,alter 等
DML(Data Manipulation Language)数据操作语言(掌握)对数据库中表的数据进行增删改.关键字:insert, delete, update 等
DQL(Data Query Language)数据查询语言 (掌握)用来查询数据库中表的记录(数据).关键字:select, where 等
DCL(Data Control Language)数据控制语言(了解)用来定义数据库的访问权限和安全级别,及创建用户.关键字:GRANT,REVOKE 等
TCL(Transaction Control Language) 事务控制语言用于控制数据库的事务操作,关键字; commit,savepoint,rollback等

 三、DDL语句

1. DDL操作数据库

创建数据库==

create database 数据库名称;

==创建数据库,并指定字符集==

create database 数据库名称 character set 字符集名;

==查询所有数据库的名称==

show databases;

==查询某个数据库的字符集:查询某个数据库的创建语句==

show create database 数据库名称;

==修改数据库的字符集==

alter database 数据库名称 character set 字符集名称;

==删除数据库==谨慎使用!!!!

drop database 数据库名称;

==查询当前正在使用的数据库名称==

select database();

==使用数据库==

use 数据库名称;

2. DDL操作表

1. 创建表

语法:

create table 表名(
    列名(字段名) 数据类型,
    列名(字段名) 数据类型,
    列名(字段名) 数据类型
    ...
);

示例:

create table student(
    id int,
    name varchar(32),
    birthday date,
    money double(5,2)
);

2. 数据类型

数据类型说明
int整数类型,例如 : age
double小数类型,例如 : score double(5,2) 111.11
date日期,只包含年月日,yyyy-MM-dd
datetime日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss
timestamp时间戳类型,包含年月日时分秒 yyyy-MM-dd HH:mm:ss 如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值
varchar可变字符 name varchar(20)
char不可变字符 name char(20)

 3. 查询表

  • ==查询某个数据库中所有的表名称==

    show tables;
  • ==查询表结构==

desc 表名;

4. 修改表

==添加一列==

语法:
    alter table 表名  add 列名 数据类型;
实例:
    alter table teacher add jieshao varchar(50);

==修改列类型==

语法:
    alter table 表名 modify 列名 新类型;
实例:
    alter table teacher modify jieshao varchar(99);

==修改列名和类型==

语法:
    alter table 表名 change 旧列名 新列名 新类型;
实例:
    alter table teacher change jieshao intro varchar(999);

==删除指定列==

语法:
    alter table 表名 drop 列名;
实例:
    alter table teacher drop intro;

==修改表字符集==

语法:
    alter table 表名 charset 字符集;
实例:
    alter table teacher charset gbk;

==修改表名==

语法:
    rename table 旧表名 to 新表名;
实例:
    rename table teacher to tch;

5. 删除表

直接删除表
    语法:
        drop table 表名;
    实例:
        drop table tch;

 四、DML语句

1.添加数据

  • 语法

    insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n); 

  • 举例

    INSERT INTO student(`id`,`name`,`birthday`) VALUES (1,'李四1','2018-11-11');

  • 注意事项

    ==列名和值要一一对应==

    表名(列名1,列名2,...列名n)写了几个字段,我们就给几个值,值的类型要跟字段类型保持一致

    ==如果表名后,不定义列名,则默认给所有列添加值【了解,不推荐使用】==

    insert into 表名 values(值1,值2,...值n);

    ==除了数字类型,其他类型需要使用引号(单双都可以)引起来==

    【建议大家都使用单引号 '' 不要使用双引号】sql语句拼接   sql语句在java代码中是一个String

    ==批量插入数据==

    INSERT INTO stu1(`id`,`name`,`birthday`) VALUES
    (1,'李四1','2020-11-11'),
    (2,'李四2','2020-11-11'),
    (3,'李四3','2020-11-11'),
    (4,'李四4','2020-11-11');

 2. 删除数据

  • 语法

    delete from 表名 [where 条件]  

  • 举例

    delete from student where id = 1;

  • 注意事项

    ==如果不加条件,则删除表中所有记录。==

    delete from student; -- 删除所有的记录

    ==如果要删除所有记录==

    delete from 表名;      -- 不推荐使用。有多少条记录就会执行多少次删除操作
    TRUNCATE TABLE 表名;   -- 推荐使用,效率更高 先删除表,然后再创建一张一样的表

3. 修改数据

  • 语法

    update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];

  • 举例

    update student set name = '王五', birthday = '2020-12-20' where id = 2;

  • 注意事项

    如果不加任何条件,则会将表中所有记录全部修改

五、DQL语句

1. 查询完整语法

select
	字段列表
from
	表名列表
where
	条件列表
group by
	分组字段
having
	分组之后的条件
order by
	排序
limit
	分页限定

2. select特点

* select 可以查询 表中的字段 表达式  常量值  函数
* 查询出的结果是一个虚拟表 不影响实际表中的数据

3. 数据准备

-- 创建表
create table stu(
	id int,
	name varchar(20),
	chinese double,
	english double,
	math double
);
-- 插入记录
insert into stu(id,name,chinese,english,math) values(1,'tom',89,78,90);
insert into stu(id,name,chinese,english,math) values(2,'jack',67,98,56);
insert into stu(id,name,chinese,english,math) values(3,'jerry',87,78,77);
insert into stu(id,name,chinese,english,math) values(5,'james',82,84,77);
insert into stu(id,name,chinese,english,math) values(6,'jack',55,85,45);
insert into stu(id,name,chinese,english,math) values(7,'tom',89,65,30);

4.简单查询

==查询所有记录==

语法:
    SELECT * FROM 表名;
举例:
    SELECT * FROM stu;
==查询表中所有学生的姓名和对应的语文成绩==

语法:
    SELECT 字段名1,字段名2... FROM 表名;
举例:
    SELECT `name`,chinese FROM stu;
    SELECT DISTINCT `name`,chinese FROM stu;
==查询表中学生姓名(去重)==

语法:
    select DISTINCT 字段名1,字段名2... FROM 表名;
举例:
    SELECT DISTINCT `name` FROM stu;
==在所有学生数学分数上加10分特长分==

SELECT `name`,math+10 FROM stu;
==统计每个学生的总分==

SELECT `name`, chinese+english+math FROM stu;

起别名

在上面求每一个学生的总成绩时,展现出一个结果视图。在这个结果有两列,分别是name, chinese+IFNULL(english,0)+math 。第一个列名,一眼就能看出这列表示的是姓名,但是第二列,你能描述出这是一个学生的总成绩吗? 显然不能。我们就要使用别名的方式,展示别名。

==语法==

as : as也可以省略

==在什么地方使用==

1. 可以用在某个字段上   name as 姓名
2. 可以用在函数上      min(sarlay) as 最低工资
3. 可以用在表上        from sutdent as s
​
   注意事项: 如果给表起了别名,后面在使用的时候,必须要用别名

==例子==

SELECT `name`, chinese+IFNULL(english,0) + math AS `总成绩` FROM stu;
​
SELECT `name`, chinese+IFNULL(english,0) + math `总成绩` FROM stu;

 5.条件查询

语法

SELECT 字段名 FROM 表名 [WHERE 条件];

运算符

运算符说明
> 、< 、<= 、>= 、= 、<> !=<>在 SQL 中表示不等于,在 mysql 中也可以使用!= 没有==
BETWEEN...AND在一个范围之内
IN( 集合)集合表示多个值,使用逗号分隔
IS NULL 不为空 is not null查询某一列为 NULL 的值,注:不能写=NULL
LIKE模糊查询 占位符: _:单个任意字符 %:多个任意字符
AND 或 &&与,SQL 中建议使用前者,后者并不通用。
OR 或 ||
NOT 或 !

导入数据

-- 创建表
CREATE TABLE stu1 (
  id int,
  name varchar(20),
  age int,
  sex varchar(5),
  address varchar(100),
  math int,
  english int
);
-- 插入记录
INSERT INTO stu1(id,NAME,age,sex,address,math,english) VALUES 
(1,'马丽丽',55,'男','杭州',66,78),
(2,'乐乐',45,'女','深圳',98,87),
(3,'李涛',55,'男','香港',56,77),
(4,'柳流',20,'女','湖南',76,65),
(5,'柳青',20,'男','湖南',86,NULL),
(6,'刘一',57,'男','香港',99,99),
(7,'马德',22,'女','香港',99,99),
(8,'德玛西亚',18,'男','南京',56,65);

条件查询

- ==查询math分数大于80分的学生==
  SELECT * FROM student2 WHERE math > 80;
- ==查询english分数小于或等于80分的学生==
  SELECT * FROM student2 WHERE english <= 80;
- ==查询age等于20岁的学生==
  SELECT * FROM student2 WHERE age = 20;
- ==查询age不等于20岁的学生==
  SELECT * FROM student2 WHERE age != 20;
- ==查询age大于35且性别为男的学生(两个条件同时满足)==
  SELECT * FROM student2 WHERE age > 35 AND sex = '男';
- ==查询age大于35或性别为男的学生(两个条件其中一个满足)==
  SELECT * FROM student2 WHERE age > 35 OR sex = '男';
- ==查询id是1或3或5的学生==
  SELECT * FROM student2 WHERE id = 1 OR id =3 OR id = 5;
  -- in关键字
-- 再次查询id是1或3或5的学生
SELECT * FROM student2 WHERE id IN(1,3,5);
- ==查询id不是1或3或5的学生==
  SELECT * FROM student2 WHERE id NOT IN(1,3,5);
- ==查询english成绩大于等于77,且小于等于87的学生==
  SELECT * FROM student2 WHERE english >=77 AND english <=87;
  SELECT * FROM student2 WHERE english BETWEEN 77 AND 87;
- ==查询英语成绩为null的学生==
  SELECT * FROM student2 WHERE english = NULL; -- null这哥们六亲不认...
SELECT * FROM student2 WHERE english IS NULL;
SELECT * FROM student2 WHERE english IS NOT NULL;
- ==查询姓马的学生==
  SELECT * FROM student2 WHERE name LIKE '马%';
- ==查询姓名中包含'德'字的学生==
  SELECT * FROM student2 WHERE name LIKE '%德%';
- ==查询姓马,且姓名有三个字的学生==
  SELECT * FROM student2 WHERE name LIKE '马__';

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

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

相关文章

Spring中的Aware接口

Spring中的Aware接口 Aware接口介绍 Aware是Spring中的接口&#xff0c;它的作用是可以让Bean获取到运行环境的相关信息。比如获取到上下文、Bean在容器中的名称等。 Spring中提供了很多Aware接口的子类&#xff0c;具体如下&#xff1a; 常用接口的作用如下&#xff1a; …

制作电子画册速成攻略,快来试试

​当今社会&#xff0c;数字媒体日益普及&#xff0c;电子画册作为一种崭新的展示方式&#xff0c;受到了越来越多人的青睐。它不仅形式新颖&#xff0c;互动性强&#xff0c;而且制作起来也并不复杂。想知道如何快速掌握制作电子画册的技巧吗&#xff1f;我来教你吧。 接下来&…

YOLO 学习和使用 (重拾机器学习)

contents a nenrons 单层神经网络 多层神经网络 CNN (Convolutional Neural Network) YOLO 5.1. YOLO(you only look once) 5.2. predict stage: 置信度 * 类别条件概率 全概率非极大值抑制&#xff0c;通过IOU 指数进行实现每个 grid cell 生成两个预测 bounding box 无…

呆马科技----构建智能可信的踏勘云平台

近年来&#xff0c;随着信息技术的快速发展&#xff0c;各个行业都在积极探索信息化的路径&#xff0c;以提升工作效率和服务质量。智慧踏勘云平台是基于区块链和大数据技术构建的全流程智慧可信踏勘解决平台。平台集远程视频、数据显示、工作调度、过程记录为一体&#xff0c;…

【图解IO与Netty系列】IO多路复用

IO多路复用 为什么要使用IO多路复用Linux的IO多路复用接口selectpollepoll 为什么要使用IO多路复用 我们常用的IO模型是BIO&#xff0c;我们Java里的IO流大多数都是BIO&#xff0c;也就是同步阻塞式IO&#xff0c;这种IO操作的好处是简单方便&#xff0c;但是缺点也很明显——…

【雷丰阳-谷粒商城 】【分布式基础篇-全栈开发篇】【00】补充

持续学习&持续更新中… 守破离 【雷丰阳-谷粒商城 】【分布式基础篇-全栈开发篇】【00】补充 WindowsCMD插件IDEAVsCode MavenvagrantDocker解决MySQL连接慢问题启动&#xff08;自动&#xff09;Docker注意切换到root用户远程访问MySQL MyBatisPlus代码地址参考 WindowsC…

vs2013使用qt Linguist以及tr不生效问题

一、qt Linguist&#xff08;语言家&#xff09;步骤流程 1、创建翻译文件,在qt选项中 2.选择对应所需的语言&#xff0c;得到.ts后缀的翻译文件 3.创建.pro文件&#xff0c;并将.ts配置在.pro文件中 3.使用qt Linguist 打开创建好的以.ts为后缀的翻译文件&#xff0c;按图所示…

YOLOv10 | 手把手教你利用yolov10训练自己数据集(含环境搭建 + 参数解析 + 数据集查找 + 模型训练、推理、导出)

一、前言 本文内含YOLOv10网络结构图 各个创新模块手撕结构图 训练教程 推理教程 参数解析 环境搭建 数据集获取等一些有关YOLOv10的内容&#xff01; 目录 一、 前言 二、整体网络结构图 三、空间-通道分离下采样 3.1 SCDown介绍 3.2 C2fUIB介绍 3.3 PSA介绍 …

Java核心: 脚本引擎和动态编译

静态语言和动态语言的在相互吸收对方的优秀特性&#xff0c;取人之长补己之短。脚本引擎和动态编译就是其中一个关键特性&#xff0c;扩展了Java的能力边界。这一篇我们主要讲两个东西: ScriptEngine&#xff0c;执行脚本语言代码&#xff0c;如JavaScript、Groovy JavaCompile…

P459 包装类Wrapper

包装类的分类 1&#xff09;针对八种基本数据类型相应的引用类型——包装类。 2&#xff09;有了类的特点&#xff0c;就可以调用类中的方法。 Boolean包装类 Character包装类 其余六种Number类型的包装类 包装类和基本数据类型的相互转换 public class Integer01 {publi…

关于数据库和数据表的基础SQL

目录 一. 数据库的基础SQL 1. 创建数据库 2. 查看当前有哪些数据库 3. 选中数据库 4. 删除数据库 5. 小结 二. 数据表的基础SQL 1. 创建数据表 2. 查看当前数据库中有哪些表 3. 查看指定表的详细情况(查看表的结构) 4. 删除表 5. 小结 一. 数据库的基础SQL 1. 创建…

Redis篇 redis基本命令和定时器原理

基本命令和定时器原理 一. exists命令二. del命令三. Expire命令四. ttl命令五. redis的过期策略六. 定时器的两种设计方式七. type命令 一. exists命令 用来判断key的值是否存在 返回值是key的个数 这样写的话&#xff0c;有没有什么区别呢&#xff1f; 效率变低&#xff0c;消…

用例篇

弱网测试 弱网测试的目的是尽可能保证用户体验&#xff0c;关注的关键点包括&#xff1a; 页面响应时间是否可以接受&#xff0c;关注包括哦热启动、冷启动时间、页面切换、前后台切换、首字时间&#xff0c;首屏时间等。页面呈现是否完成一致。超时文案是否符合定义&#xf…

YoloV1模型

You Only Look Once 文章目录 You Only Look Once置信度定义类别条件概率NMSnp.maxmiumnp.argsort() Yolov1直接采用网络特征输出&#xff0c;实现置信度预测、分类、边界框回归&#xff1b; 核心内容总结&#xff1a; 输入图像划分为 S S 网格。如果对象的中心落入网格单元中…

Java——认识Java

一、介绍 1、起源 Java 是由 Sun Microsystems 于 1995 年推出的一种面向对象的编程语言和计算平台。由詹姆斯高斯林&#xff08;James Gosling&#xff0c;后来被称为Java之父&#xff09;和他的同事们共同研发。后来&#xff0c;Sun 公司被 Oracle&#xff08;甲骨文&#…

vue3 vite动态根据字符串加载组件

1 原理 import.meta.glob() 其实不仅能接收一个字符串&#xff0c;还可以接收一个字符串数组&#xff0c;就是匹配多个位置 let RouterModules import.meta.glob(["/src/view/*/*.vue", "/src/view/*.vue"]);这样我们就拿到了相对路劲的组件对象&#xf…

leedcode【142】. 环形链表 II——Java解法

Problem: 142. 环形链表 II 思路解题方法复杂度Code性能 思路 1.用快慢指针找到相遇的点&#xff08;快指针一次走一步&#xff0c;慢指针一次走两步&#xff09; 2.一个指针从head开始&#xff0c;一个指针从相遇点开始&#xff0c;一次一步&#xff0c;相遇处即为环入口 解题…

【模版方法设计模式】

文章目录 模板方法设计模式模板方法的设计原则模板方法设计模式组成部分代码实现抽象类实现具体实现类执行 模板方法设计模式 模版方法设计模式&#xff08;Template Method Pattern&#xff09;是一种行为设计模式&#xff0c;它定义了一个操作中的算法骨架&#xff0c;而将一…

网络应用层之(1)DHCPv6协议

网络应用层之(1)DHCPv6协议 Author: Once Day Date: 2024年5月26日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 全系列文章可参考专栏: 通信网络技术_Once-Day的博客-C…

设计模式八股文

什么是设计模式&#xff1f; 设计模式是软件开发过程中经常遇到的问题的通用解决方案。类似于前人总结的经验&#xff0c;遇到相似问题的时候有个参考。 设计模式七大基本原则&#xff1f; 单一职责&#xff1a;一个类应该只作一件事情。将功能分为小的独立的单元。开放封闭…