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 '马__';

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 小游戏——贪吃蛇

Python 小游戏——贪吃蛇 文章目录 Python 小游戏——贪吃蛇项目介绍环境配置代码设计思路1. 初始化和变量定义2. 创建游戏窗口和FPS控制器3. 初始化贪吃蛇和食物的位置4. 控制贪吃蛇的方向和分数5. 主游戏循环 难点分析源代码呈现代码结果 项目介绍 贪吃蛇游戏是一款通过上下…

Java核心:注解处理器

Java提供了一个javac -processor命令支持处理标注有特定注解的类&#xff0c;来生成新的源文件&#xff0c;并对新生成的源文件重复执行。执行的命令大概是这样的: javac -XprintRounds -processor com.keyniu.anno.processor.ToStringProcessor com.keyniu.anno.processor.Po…

【C++】二分查找算法:x的平方根

1.题目 2.算法思路 看到题目可能不容易想到二分查找。 这题考察我们对算法的熟练程度。 二分查找的特点&#xff1a;数组具有二段性(不一定有序)。 题目中没有数组&#xff0c;我们可以造一个从0到x的数组&#xff0c;然后利用二分查找找到对应的值即可。 3.代码 class S…

八种单例模式

文章目录 1.单例模式基本介绍1.介绍2.单例模式八种方式 2.饿汉式&#xff08;静态常量&#xff0c;推荐&#xff09;1.基本步骤1.构造器私有化&#xff08;防止new&#xff09;2.类的内部创建对象3.向外暴露一个静态的公共方法 2.代码实现3.优缺点分析 3.饿汉式&#xff08;静态…

如何查看热门GPT应用?

1、登陆chatgpt 2、访问 https://chatgpt.com/gpts 3、在该界面&#xff0c;可以搜索并使用image generator, Write For Me&#xff0c;Language Teature等热门应用。

【Qt 学习笔记】Qt窗口 | 菜单栏 | QMenuBar的使用及说明

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt窗口 | 菜单栏 | QMenuBar的使用及说明 文章编号&#xff1a;Qt 学习…

Go微服务: Nacos的搭建和基础API的使用

Nacos 概述 文档&#xff1a;https://nacos.io/docs/latest/what-is-nacos/搭建&#xff1a;https://nacos.io/docs/latest/quickstart/quick-start-docker/有很多种搭建方式&#xff0c;我们这里使用 docker 来搭建 Nacos 的搭建 这里&#xff0c;我们选择单机模式&#xf…

Redis可视化工具:Another Redis Desktop Manager下载安装使用

1.Github下载 github下载地址&#xff1a; Releases qishibo/AnotherRedisDesktopManager GitHub 2. 安装 直接双击exe文件进行安装 3. 连接Redis服务 先启动Redis服务&#xff0c;具体启动过程可参考&#xff1a; Windows安装并启动Redis服务端&#xff08;zip包&#xff09…

从程序被SQL注入来MyBatis 再谈 #{} 与 ${} 的区别

缘由 最近在的一个项目上面&#xff0c;发现有人在给我搞 SQL 注入&#xff0c;我真的想说我那么点资源测试用的阿里云服务器&#xff0c;个人估计哈&#xff0c;估计能抗住他的请求。狗头.png 系统上面的截图 数据库截图 说句实在的&#xff0c;看到这个之后我立马就是在…

Nginx文件解析漏洞复现:CVE-2013-4547

漏洞原理 CVE-2013-4547漏洞是由于非法字符空格和截止符导致Nginx在解析URL时的有限状态机混乱&#xff0c;导致攻击者可以通过一个非编码空格绕过后缀名限制。假设服务器中存在文件1. jpg&#xff0c;则可以通过改包访问让服务器认为访问的为PHP文件。 漏洞复现 开启靶场 …

【数据结构】快速排序详解!

文章目录 1. 快速排序的非递归版本2. 快速排序2.1 hoare 版本一2.2 挖坑法 &#x1f427;版本二2.3 前后指针 版本三2.4 调用以上的三个版本的快排 3. 快速排序的优化 1. 快速排序的非递归版本 &#x1f192;&#x1f427;关键思路&#xff1a; &#x1f34e;① 参数中的begin…

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

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

嵌入式进阶——舵机控制PWM

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 舵机信号线代码示例初始化PWM初始化UART打印日志初始化外部中断Extimain函数 舵机最早用于船舶上实现转向功能,由于可以通过程序连…

Spring从零开始学使用系列(四)之@PostConstruct和@PreDestroy注解的使用

如果各位老爷觉得可以&#xff0c;请点赞收藏评论&#xff0c;谢谢啦&#xff01;&#xff01; 文章中涉及到的图片均由AI生成 公众号在最下方&#xff01;&#xff01;&#xff01; 目录 1. 介绍 1.1 PostConstruct概述 1.2 PreDestroy概述 2. 基本用法 2.1 注册CommonAnn…

JS根据所选ID数组在源数据中取出对象

let selectIds [1, 3] // 选中id数组let allData [{ id: 1, name: 123 },{ id: 2, name: 234 },{ id: 3, name: 345 },{ id: 4, name: 456 },] // 源数据let newList [] // 最终数据selectIds.map((i) > {allData.filter((item) > {item.id i && newList.pus…

MyBatis复习笔记

3.Mybatis复习 3.1 xml配置 properties&#xff1a;加载配置文件 settings&#xff1a;设置驼峰映射 <settings><setting name"mapUnderscoreToCamelCase" value"true"/> </settings>typeAliases&#xff1a;类型别名设置 #这样在映射…

力扣刷题---LCS 02. 完成一半题目【简单】

题目描述 有 N 位扣友参加了微软与力扣举办了「以扣会友」线下活动。主办方提供了 2*N 道题目&#xff0c;整型数组 questions 中每个数字对应了每道题目所涉及的知识点类型。 若每位扣友选择不同的一题&#xff0c;请返回被选的 N 道题目至少包含多少种知识点类型。 示例 1&…

MySQL--InnoDB体系结构

目录 一、物理存储结构 二、表空间 1.数据表空间介绍 2.数据表空间迁移 3.共享表空间 4.临时表空间 5.undo表空间 三、InnoDB内存结构 1.innodb_buffer_pool 2.innodb_log_buffer 四、InnoDB 8.0结构图例 五、InnoDB重要参数 1.redo log刷新磁盘策略 2.刷盘方式&…

自然资源-各级国土空间总体规划的审查要点及流程总结

自然资源-各级国土空间总体规划的审查要点及流程总结 国土空间规划是对一定区域国土空间开发保护在空间和时间上作出的安排&#xff0c;包括总体规划、详细规划和相关专项规划。 国土空间规划管理是国土空间规划中重要的一环。中共中央、国务院发布《关于建立国土空间规划体系…

京东应届生公司内网说了一句‘什么时候被pdd收购‘,结果惨遭辞退

京东应届生公司内网说了一句’什么时候被pdd收购’&#xff0c;结果惨遭公司开除 这个事最近在圈子讨论比较多 前二天&#xff0c;有一个上海交大毕业的应届生&#xff0c;在京东实习了9个月&#xff0c;好不容易转正12天后&#xff0c;只因在内网说了一句话&#xff0c;就被…