MYSQL的安装基础语法笔记
MYSQL基础语法
学习目标
- 能够理解数据库的概念(知道数据库是用来干嘛的)
- 能够安装MySQL数据库
- 能够启动,关闭及登录MySQL
- 能够使用SQL语句操作数据库(创建、删除、修改、查询数据库)
- 能够使用SQL语句操作表结构(创建、删除、修改、查询表)
- 能够使用SQL语句进行数据的添加修改和删除的操作(掌握)
- 能够使用SQL语句简单查询数据(重点掌握)
第1章 数据库的介绍
1.1 数据库概述
1.1.1 什么是数据库
存储数据的仓库. 其本质是一个文件系统,数据库按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。
1.1.2 数据的存储方式
数据保存在内存中
int[] arr = newint[]{1, 2, 3, 4}; ArrayList<Integer>list = new ArrayList<Integer>(); list.add(1);
new出来的对象存储在堆中.堆是内存中的一小块空间
优点:内存速度快
缺点:断电/程序退出,数据就清除了.内存价格贵数据保存在普通文件中
优点:永久保存
缺点:查找,增加,修改,删除数据比较麻烦,效率低数据保存在数据库中
优点:永久保存,通过SQL语句比较方便的操作数据库
1.2 数据库的优点
数据库是按照特定的格式将数据存储在文件(硬盘)中,通过SQL语句可以方便的对大量数据进行增、删、改、查操作,数据库是对大量的信息进行管理的高效解决方案。
1.3 常见数据库
)]
MYSQL:开源免费的数据库,小型的数据库.已经被Oracle收购了.MySQL6.x版本也开始收费。
Oracle:收费的大型数据库,Oracle公司的产品。Oracle收购SUN公司,收购MYSQL。
DB2 :IBM公司的数据库产品,收费的。常应用在银行系统中.
SQLServer:MicroSoft 公司收费的中型的数据库。C#、.net等语言常使用。
SyBase:已经淡出历史舞台。提供了一个非常专业数据建模的工具PowerDesigner。
SQLite: 嵌入式的小型数据库,应用在手机端。
常用数据库:MYSQL,Oracle
在web应用中,使用的最多的就是MySQL数据库,原因如下:
- 开源、免费
- 功能足够强大,足以应付web应用开发(最高支持千万级别的并发访问)
第2章 数据库的安装与使用
2.1 数据库的安装
打开下载的mysql安装文件双击解压缩,运行“mysql-5.5.40-win32.msi”。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EQj680a6-1576335235518)(image\MYSQL安装01.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hxRK72Kq-1576335235521)(image\MYSQL安装02.png)]选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,选择“Custom”,按“next”键继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6iIn7gbO-1576335235525)(image\MYSQL安装03.png)]点选“Browse”,手动指定安装目录。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X2FdJXaZ-1576335235527)(image\MYSQL安装04.png)]填上安装目录,我的是“d:\Program Files (x86)\MySQL\MySQL Server 5.0”,按“OK”继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qrKpmclD-1576335235529)(image\MYSQL安装05.png)]确认一下先前的设置,如果有误,按“Back”返回重做。按“Install”开始安装。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GbmOpnVb-1576335235534)(image\MYSQL安装06.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-H8vIve5k-1576335235539)(image\MYSQL安装07.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LbByB1Tb-1576335235543)(image\MYSQL安装08.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pHIGOPlC-1576335235546)(image\MYSQL安装09.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oBSzM4py-1576335235548)(image\MYSQL安装10.png)]正在安装中,请稍候,直到出现下面的界面, 则完成MYSQL的安装
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HYNigu0c-1576335235549)(image\MYSQL安装11.png)]
数据库安装好了还需要对数据库进行配置才能使用
MYSQL的配置
安装完成了,出现如下界面将进入mysql配置向导。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6EsK4Mhz-1576335235551)(image\MYSQL安装12.png)]选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标准配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0uf0lRzE-1576335235552)(image\MYSQL安装13.png)]选择服务器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(服务器类型,mysql占用较多资源)”、“Dedicated MySQL Server Machine(专门的数据库服务器,mysql占用所有可用资源)”
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JXQSLiQk-1576335235554)(image\MYSQL安装14.png)]选择mysql数据库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(服务器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional),按“Next”继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2eBkE54S-1576335235557)(image\MYSQL安装15.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-68OQsOVO-1576335235559)(image\MYSQL安装16.png)]选择网站并发连接数,同时连接的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设置,自己输一个数)”。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HizQklnj-1576335235560)(image\MYSQL安装17.png)]是否启用TCP/IP连接,设定端口,如果不启用,就只能在自己的机器上访问mysql数据库了,在这个页面上,您还可以选择“启用标准模式”(Enable Strict Mode),这样MySQL就不会允许细小的语法错误。如果是新手,建议您取消标准模式以减少麻烦。但熟悉MySQL以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按“Next”继续
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1jsnngut-1576335235562)(image\MYSQL安装18.png)]就是对mysql默认数据库语言编码进行设置(重要),一般选UTF-8,按 “Next”继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n5z5BfRY-1576335235568)(image\MYSQL安装19.png)]选择是否将mysql安装为windows服务,还可以指定Service Name(服务标识名称),是否将mysql的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的文件,而不用指出目录名,比如连接,“mysql.exe -uusername -ppassword;”就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按“Next”继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-t5YuZivl-1576335235569)(image\MYSQL安装20.png)]询问是否要修改默认root用户(超级管理)的密码。“Enable root access from remote machines(是否允许root用户在其它的机器上登陆,如果要安全,就不要勾上,如果要方便,就勾上它)”。最后“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连接数据库,不能操作数据,包括查询)”,一般就不用勾了,设置完毕,按“Next”继续。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lqbKuFQ3-1576335235570)(image\MYSQL安装21.png)]确认设置无误,按“Execute”使设置生效,即完成MYSQL的安装和配置。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lGploicy-1576335235576)(image\MYSQL安装22.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Beu1A2Q5-1576335235578)(image\MYSQL安装23.png)]
注意:设置完毕,按“Finish”后有一个比较常见的错误,就是不能“Start service”,一般出现在以前有安装mysql的服务器上,解决的办法,先保证以前安装的mysql服务器彻底卸载掉了;不行的话,检查是否按上面一步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将mysql安装目录下的data文件夹备份,然后删除,在安装完成后,将安装生成的 data文件夹删除,备份的data文件夹移回来,再重启mysql服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kk224yUq-1576335235580)(image\MYSQL安装24.png)]
解决方法:卸载MySQL,重装MySQL
2.3 数据库的卸载
停止window的MySQL服务。
找到“控制面板”-> “管理工具”-> “服务”,停止MySQL后台服务。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ocQuWch4-1576335235582)(image\MYSQL卸载01.png)]卸载MySQL安装程序。找到“控制面板”-> “程序和功能”,卸载MySQL程序。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nztYudTX-1576335235585)(image\MYSQL卸载02.png)]删除MySQL安装目录下的所有文件。
删除c盘ProgramDate目录中关于MySQL的目录。路径为:C:\ProgramData\MySQL(是隐藏文件,需要显示出来)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gegHGBoE-1576335235587)(image\MYSQL卸载03.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vmOm1jtM-1576335235591)(image\MYSQL卸载04.png)]
2.4 数据库服务的启动和关闭
MySQL启动方式和普通的windows程序双击启动方式不同,分为以下2种:
Windows服务方式启动
操作步骤:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lqgDjYGZ-1576335235593)(image\mysql启动01.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1pokZmMW-1576335235595)(image\mysql启动02.png)]DOS命令方式启动
操作步骤:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-r2yqNkzA-1576335235597)(image\mysql启动03.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hTyBm6rO-1576335235599)(image\mysql启动04.png)]启动MYSQL:
net start mysql
停止MYSQL:net stop mysql
2.5 控制台连接数据库服务器
MySQL是一个需要账户名密码登录的数据库,登陆后使用,它提供了一个默认的root账号,使用安装时设置的密码即可登录
登录格式1:
mysql -u用户名 -p密码
例如:mysql –uroot -proot
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YYYzqmAM-1576335235605)(image\MYSQL登录01.png)]
后输入密码方式:mysql -u用户名 -p回车
密码
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1LIArNGO-1576335235607)(image\MYSQL登录04.png)]
登录格式2:
mysql -hip地址 -u用户名 -p密码
(用于连接另外一台电脑的MySQL服务器,勾选远程连接才能192…ip)
例如:mysql –h127.0.0.1 –uroot -proot
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-S0ZQWbx2-1576335235609)(image\MYSQL登录02.png)]登录格式3:
mysql --host=ip地址 --user=用户名 --password=密码
(没有意义)
例如:mysql --host=localhost --user=root --password=root
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7APUtMl2-1576335235610)(image\MYSQL登录03.png)]退出MySQL:
exit,quit
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dXzy2S89-1576335235611)(image\MYSQL退出01.png)]
2.6 SQLyog图形化工具安装
SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Rko2iOpP-1576335235615)(image\SQLYog介绍.png)]
- 双击[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fHJpzSvy-1576335235617)(image\SQLYog程序.png)]
- 一直下一步,直到出现下面对话框
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wXu3u6bL-1576335235619)(image\SQLYog注册.png)] - 双击[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gBDKPfGi-1576335235620)(image\SQLYog破解.png)]进行注册
- 重启SQLyog即可
- 使用SQLyog登录数据库
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EQeOK4dS-1576335235621)(image\SQLyog使用01.png)]
2.7 MySQL服务器目录结构
│-- bin:mysql相关的可执行文件*.exe│-- MySQLInstanceConfig.exe mysql的配置程序
│-- data: mysql自带的数据库文件
│-- include: c语言的头文件(不用关注)
│-- lib: 存放mysql使用到的dll动态库(相当于jar包,不用关注)
│-- my.ini mysql的配置文件,配置了mysql的相关信息
2.8 数据库管理系统
数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据
2.9 数据库管理系统、数据库和表的关系
数据库管理程序(DBMS)可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。为保存应用中实体的数据,一般会在数据库创建多个表,以保存程序中实体的数据。数据库管理系统、数据库和表的关系如图所示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-keUcyQrl-1576335235626)(image\DBMS.png)]
先有数据库 → 再有表 → 再有数据
一个库包含多个表
2.10 实体类与表的对应关系
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XuDHLcMT-1576335235628)(image\实体类与表的对应关系.png)]
第3章 SQL语句
3.1 SQL的概念
3.1.1 什么是SQL
结构化查询语言(Structured Query Language)简称SQL,SQL语句就是对数据库进行操作的一种语言。
3.1.2 SQL作用
通过SQL语句我们可以方便的操作数据库中的数据、表、数据库。
SQL是数据库管理系统都需要遵循的规范。不同的数据库生产厂商都支持SQL语句,但都有特有内容。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-I9RsAzzy-1576335235630)(image\SQL规范.png)]
3.1.2 SQL语句分类
DDL(Data Definition Language)数据定义语言,用于创建、修改、删除数据库和表(了解)
用来定义数据库对象:数据库,表,列等。关键字:create(创建), drop(删除),alter(修改)等DML(Data Manipulation Language)数据操作语言(掌握)
用来对数据库中表中的数据进行增删改。关键字:insert(添加数据), delete(删除数据), update(修改数据)等DCL(Data Control Language)数据控制语言(了解)
用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE等
TCL(Transaction Control Language) 事务控制语言
用于控制数据库的事务操作,关键字; COMMIT,SAVEPOINT,ROLLBACK等
DQL(Data Query Language) 数据查询语言(重中之重)
DQL语言并不是属于MYSQL官方的分类,但是对数据库的操作最多就是查询,所以
我们的程序员把查询语句的语句称作为DQL语言
3.2 SQL通用语法
- SQL语句可以单行或多行书写。SQL语句是没有分号的,在cmd中写SQL语句就要加分号,";"是cmd中一句命令的结束标识
- 可使用空格和缩进来增强语句的可读性。
- MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。
SELECT * FROM student;
- 3种注释(针对在"SQLYog"中写SQL语句)
单行注释: – 注释内容 或 # 注释内容(mysql特有)
多行注释: /* 注释 */
3.3 DDL语句//建库建表(带有字段),搞结构
3.3.1 DDL操作数据库
3.3.1.1 创建数据库,create
直接创建数据库
CREATE DATABASE 数据库名;
判断是否存在并创建数据库
CREATE DATABASE IF NOT EXISTS 数据库名;
创建数据库并指定字符集(编码表)
CREATE DATABASE 数据库名 CHARACTER SET 字符集;
具体操作:
直接创建数据库db1
CREATE DATABASE db1;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0zJ689Uz-1576335235632)(image\直接创建数据库.png)]
判断是否存在并创建数据库db2
CREATE DATABASE IF NOT EXISTS db2;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DzCDb9of-1576335235635)(image\判断是否存在并创建数据库.png)]
创建数据库并指定字符集为gbk
CREATE DATABASE db2 CHARACTER SET gbk;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5PfedLgN-1576335235636)(image\创建数据库并指定字符集.png)]
3.3.1.2 查看数据库,show
查看所有的数据库
SHOW databases;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pI7ElK9v-1576335235638)(image\查看所有数据库.png)]查看某个数据库的定义信息
SHOW CREATE DATABASE 数据库名;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QkTWI89p-1576335235641)(image\查看某个数据库的定义信息.png)]
3.3.1.3 修改数据库,alter
修改数据库字符集格式
ALTER DATABASE 数据库名 CHARACTER SET 字符集;
具体操作:
- 将db3数据库的字符集改成utf8
ALTER DATABASE db3 CHARACTER SET utf8;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lQ0FHNjr-1576335235644)(image\修改数据库字符集.png)]
3.3.1.4 删除数据库,用drop丢弃而不是delete!!!
DROP DATABASE 数据库名;
具体操作:
- 删除db2数据库
DROP DATABASE db2;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4JhOBYAx-1576335235647)(image\删除数据库.png)]
3.3.1.5 使用数据库,要注意,需要记忆!!!
- 查看正在使用的数据库
SELECT DATABASE();
- 使用/切换数据库
USE 数据库名;
具体操作:
- 查看正在使用的数据库
SELECT DATABASE();
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SeWRslK1-1576335235650)(image\查看正在使用的数据库.png)]
- 使用db1数据库
USE db1;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-E2ikCFDN-1576335235651)(image\使用db1数据库.png)]
3.3.2 DDL操作表
前提先使用某个数据库!!!
3.3.2.1 创建表,create,跟数据库类似,中间插入(),指定字段和类型,记忆!!!
CREATE TABLE 表名 (字段名1 字段类型1, 字段名2 字段类型2…);
建议写成如下格式:
CREATE TABLE 表名 (
字段名1 字段类型1,
字段名2 字段类型2
);
关键字说明:
CREATE -- 表示创建
TABLE -- 表示创建一张表
MySQL数据类型:
MySQL中的我们常用的数据类型如下:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oFGsJpHh-1576335235659)(image\MYSQL常用数据类型.png)]
扩展:char和varchar的区别:char固定长度,不够用空格补全,一般使用varchar:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2VpyGDwl-1576335235660)(image\char和varchar的区别.png)]
详细的数据类型如下(不建议详细阅读!有用到再回来查查即可)
分类 | 类型名称 | 说明 |
---|---|---|
整数类型 | tinyInt | 整数(有符号:-128,127,无符号:0-255) |
smallint | 小的整数 | |
mediumint | 中等大小的整数 | |
int(integer) | 普通大小的整数 | |
小数类型 | float | 单精度浮点数 |
double | 双精度浮点数 | |
日期类型 | year | YYYY 1901~2155 |
time | HH:MM:SS -838:59:59~838:59:59 | |
date | YYYY-MM-DD 1000-01-01~9999-12-3 | |
datetime | YYYY-MM-DD HH:MM:SS 1000-01-01 00:00:00~ 9999-12-31 23:59:59 | |
timestamp | YYYY-MM-DD HH:MM:SS 19700101 00:00:01 UTC~2038-01-19 03:14:07UTC | |
文本、二进制类型 | CHAR(M) | char(11),该字段是字符串类型,写并且最多能传入11个字符,固定长度 |
VARCHAR(M) | varchar(11),该字段是字符串类型,写并且最多能传入11个字符,可变长度 | |
TINYBLOB | 允许长度0~255字节 | |
BLOB | 允许长度0~65535字节 | |
MEDIUMBLOB | 允许长度0~167772150字节 | |
LONGBLOB | 允许长度0~4294967295字节 | |
TINYTEXT | 允许长度0~255字节 | |
TEXT | 允许长度0~65535字节 | |
MEDIUMTEXT | 允许长度0~167772150字节 | |
LONGTEXT | 允许长度0~4294967295字节 | |
VARBINARY(M) | 允许长度0~M个字节的变长字节字符串 | |
BINARY(M) | 允许长度0~M个字节的定长字节字符串 |
具体操作:
创建student表包含id,name,birthday字段
CREATE TABLE student (id INT,name VARCHAR(20),birthday DATE
);
3.3.2.2 查看表(了解),比数据库了show,多了desc表名查看表结构,如里面的字段类型和默认值等,记忆!!!
查看某个数据库中的所有表
SHOW TABLES;
查看表结构//记忆
DESC 表名;
查看创建表的SQL语句(掌握)
SHOW CREATE TABLE 表名;
具体操作:
查看mysql数据库中的所有表
SHOW TABLES;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y0hp9FpL-1576335235664)(image\查看某个数据库中的所有表.png)]
查看student表的结构
DESC student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YotqSXzX-1576335235666)(image\查看student表的结构.png)]
查看student的创建表SQL语句
SHOW CREATE TABLE student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PQYWOR9k-1576335235668)(image\查看student的创建表SQL语句.png)]
3.3.2.3 快速创建一个表结构相同的表,like,像哪个旧表,即创建新表像哪个旧表,记忆!!!
CREATE TABLE 新表名 LIKE 旧表名;
具体操作:
- 创建s1表,s1表结构和student表结构相同
CREATE TABLE s1 LIKE student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OJaXnqJI-1576335235669)(image\创建表结构相同的表.png)]
3.3.2.4 删除表,drop,跟删除数据库几乎一样
- 直接删除表
DROP TABLE 表名;
- 判断表是否存在并删除表
DROP TABLE IF EXISTS 表名;
具体操作:
- 直接删除表s1表
DROP TABLE s1;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZJd1sb4n-1576335235670)(image\直接删除表.png)]
- 判断表是否存在并删除s1表
DROP TABLE IF EXISTS s1;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OvbNZTzF-1576335235672)(image\判断表存在并删除.png)]
3.3.2.5 修改表结构(了解!!!)
修改表结构使用不是很频繁,只需要了解,不需要记太多,等需要使用的时候再回来查即可!!!
添加表列(修改表增加字段和类型)
ALTER TABLE 表名 ADD 列名 类型;
具体操作:
- 为学生表添加一个新的字段remark,类型为varchar(20)
ALTER TABLE student ADD remark VARCHAR(20);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-F2soTnrq-1576335235673)(image\添加字段.png)]
- 为学生表添加一个新的字段remark,类型为varchar(20)
修改列类型(修改表修改已有字段类型)
ALTER TABLE 表名 MODIFY 列名 新的类型;
具体操作:- 将student表中的remark字段的改成varchar(100)
ALTER TABLE student MODIFY remark VARCHAR(100);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RpotInJq-1576335235675)(image\修改字段类型.png)]
- 将student表中的remark字段的改成varchar(100)
修改列名(修改表改变旧字段,指定新字段和它的类型)
ALTER TABLE 表名 CHANGE 旧列名 新列名 类型;
具体操作:- 将student表中的remark字段名改成intro,类型varchar(30)
ALTER TABLE student CHANGE remark intro varchar(30);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tIhYEvml-1576335235679)(image\修改表字段名称.png)]
- 将student表中的remark字段名改成intro,类型varchar(30)
删除列(修改表丢弃删除字段,所以不要类型!!!,要特别注意!!!)
ALTER TABLE 表名 DROP 列名;
具体操作:- 删除student表中的字段intro
ALTER TABLE student DROP intro;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FahnHV6g-1576335235680)(image\删除字段.png)]
- 删除student表中的字段intro
修改表名(重命名旧表名到新的名字)
RENAME TABLE 表名 TO 新表名;
具体操作:- 将学生表student改名成student2
RENAME TABLE student TO student2;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UD8wbp56-1576335235681)(image\修改表名.png)]
- 将学生表student改名成student2
修改表字符集(跟数据库类似,不用记)
ALTER TABLE 表名 character set 字符集;
具体操作:- 将sutden2表的编码修改成gbk
ALTER TABLE student2 character set gbk;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aCabYVPK-1576335235683)(image\修改字符集.png)]
- 将sutden2表的编码修改成gbk
3.4 DML语句(重点掌握)
3.4.1 插入记录,insert into …values…
3.4.1.1 插入全部字段
(插入到哪个表里面,指定字段,指定值,都用(),别忘了指定值的关键字VALUES)//记忆
- 所有的字段名都写出来
INSERT INTO 表名 (字段名1, 字段名2, 字段名3…) VALUES (值1, 值2, 值3);
- 不写字段名,简化格式,要插入所有
INSERT INTO 表名 VALUES (值1, 值2, 值3…);
3.4.1.2 插入部分数据
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
没有添加数据的字段会使用NULL赋值
关键字说明
INSERT INTO 表名 – 表示往哪张表中添加数据 (字段名1, 字段名2, …) -- 要给哪些字段设置值 VALUES (值1, 值2, …); -- 设置具体的值
注意
- 值与字段必须对应,个数相同,类型相同
- 值的数据大小必须在字段的长度范围内
- 除了数值类型外,其它的字段类型的值必须使用引号引起来。(建议单引号,好看点)
- 如果要插入空值,可以不写字段,或者插入null表示
具体操作:
- 插入部分数据,往学生表中添加 id, name, age, sex数据
INSERT INTO student (id, NAME, age, sex) VALUES (1, '张三', 20, '男');
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-A6onqK9b-1576335235686)(image\添加部分数据.png)]
向表中插入所有字段
- 所有的字段名都写出来
INSERT INTO student (NAME, id, age, sex, address) VALUES ('李四', 2, 23, '女', '广州');
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rhXkyPDY-1576335235689)(image\所有字段都添加数据.png)]
- 不写字段名
INSERT INTO student VALUES (3, '王五', 18, '男', '北京');
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aAhXDZxM-1576335235691)(image\添加所有字段数据.png)]
3.4.1.3 DOS命令窗口操作数据乱码问题的解决(如插入中文乱码问题)郭德纲
当我们使用DOS命令行进行SQL语句操作如有有中文会出现乱码,导致SQL执行失败
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dDURSKvT-1576335235697)(image\DOS中文乱码01.png)]
错误原因:因为MySQL的客户端设置编码是utf8,而系统的DOS命令行编码是gbk,编码不一致导致的乱码
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2ZhtOLdS-1576335235706)(image\DOS中文乱码02.png)]
查看 MySQL 内部设置的所有编码
show variables like 'character%';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OWwmq0Xw-1576335235707)(image\DOS中文乱码03.png)]
解决方案:修改client、connection、results的编码为GBK,保证和DOS命令行编码保持一致
单独设置
set character_set_client=gbk; set character_set_connection=gbk; set character_set_results=gbk;
快捷设置,常用set names gbk;即临时设置所有字符集编码(名字)为gbk,记忆!!!
set names gbk;
注意:以上2种方式为临时方案,退出DOS命令行就失效了,需要每次都配置
修改MySQL安装目录下的my.ini文件,重启服务所有地方生效。此方案将所有编码都修改了所以[不建议]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SGfBdxvL-1576335235709)(image\DOS中文乱码04.png)]
3.4.1.4 蠕虫复制,(创建新表像哪个旧的表,然后插入到新表,选择来自旧表的数据,记忆!!!)
什么是蠕虫复制:在已有的数据基础之上,将原来的数据进行复制,插入到对应的表中
语法格式:INSERT INTO 表名1 SELECT * FROM 表名2;
作用:将表名2
中的数据复制到表名1
中
具体操作:
- 创建student2表,student2结构和student表结构一样
CREATE TABLE student2 LIKE student;
- 将student表中的数据添加到student2表中
INSERT INTO student2 SELECT * FROM student;
部分复制(新表要()指定字段,选择旧表字段,记忆!!!):
注意:如复制student表中name,age字段数据到student2表中使用如下格式:
INSERT INTO student2(NAME, age) SELECT NAME, age FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BGYPcveu-1576335235712)(image\蠕虫复制.png)]
3.4.2 更新表记录(更新表设置字段进行赋值,可增加where条件,简单)
不带条件修改数据
UPDATE 表名 SET 字段名=值;
带条件修改数据
UPDATE 表名 SET 字段名=值 WHERE 字段名=值;
关键字说明
UPDATE: 修改数据 SET: 修改哪些字段 WHERE: 指定条件
具体操作:
不带条件修改数据,将所有的性别改成女
UPDATE student SET sex='女';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8wLpMnG5-1576335235714)(image\修改所有数据.png)]
带条件修改数据,将id号为2的学生性别改成男
UPDATE student SET sex='男' WHERE id=2;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gKlAd272-1576335235719)(image\带条件修改.png)]
一次修改多个列,把id为3的学生,年龄改成26岁,address改成北京(更新表设置字段,进行赋值,逗号隔)
UPDATE student SET age=26, address='北京' WHERE id=3;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BZkoYl3B-1576335235721)(image\一次性修改2个字段.png)]
3.4.3 删除表记录(删除数据要告诉我来自哪个表,delete from表名,简单)
不带条件删除数据
DELETE FROM 表名;
带条件删除数据
DELETE FROM 表名 WHERE 字段名=值;
truncate删除表记录
TRUNCATE TABLE 表名;
truncate和delete的区别:
- delete是将表中的数据一条一条删除,效率低
- truncate是将整个表摧毁,重新创建一个新的表,新的表结构和原来表结构一模一样,效率高
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-b0nhnMFJ-1576335235726)(image\truncate.png)]
具体操作:
带条件删除数据,删除id为3的记录
DELETE FROM student WHERE id=3;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mH52hjpO-1576335235728)(image\删除满足条件的记录.png)]
不带条件删除数据,删除表中的所有数据
DELETE FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-y9eGJG6J-1576335235736)(image\删除所有记录.png)]
3.5 DQL(重中之重)
查询不会对数据库中的数据进行修改.只是一种显示数据的方式
3.5.1 简单查询
3.5.1.1 查询表中所有数据(所有行和所有列),简单
使用*表示所有列(即星号,代表所有字段)
SELECT * FROM 表名;
具体操作:SELECT * FROM student4;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4MTXGyhc-1576335235742)(image\查询所有列.png)]
写出查询每列的名称
SELECT 字段名1, 字段名2, 字段名3, ... FROM 表名;
具体操作:SELECT id, NAME ,age, sex, address FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Q4wc6umJ-1576335235745)(image\查询所有列.png)]
3.5.1.2 查询指定列,简单
查询指定列的数据,多个列之间以逗号分隔
SELECT 字段名1, 字段名2... FROM 表名;
具体操作:
查询student表中的name 和 age 列
SELECT NAME, age FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nlX9wntT-1576335235748)(image\查询指定字段.png)]
3.5.1.3 别名查询,(as作为别名,可以省略as,记忆!!!)
查询时给列、表指定别名需要使用AS关键字
使用别名的好处是方便观看和处理查询到的数据
SELECT 字段名1 AS 别名, 字段名2 AS 别名... FROM 表名;
SELECT 字段名1 AS 别名, 字段名2 AS 别名... FROM 表名 AS 表别名;
注意:查询给表取别名目前还看不到效果,需要到多表查询的时候才能体现出好处
AS关键字可以省略具体操作://编号
- 查询sudent表中name 和 age 列,name列的别名为”姓名”,age列的别名为”年龄”
SELECT NAME AS 姓名, age AS 年龄 FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BUboStsd-1576335235749)(image\查询字段别名.png)]
- 查询sudent表中name和age列,student表别名为s
SELECT NAME, age FROM student AS s;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dZXXDvKS-1576335235751)(image\查询表别名.png)]
查询给表取别名目前还看不到效果,需要到多表查询的时候才能体现出好处
3.5.1.4 清除重复值(去重查询),简单查询,中插distinct去重
- 查询指定列并且结果不出现重复数据
SELECT DISTINCT 字段名 FROM 表名;
- 具体操作:
- 查询name,age列并且结果不出现重复name和age
SELECT DISTINCT NAME, age FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mH5aw1gN-1576335235756)(image\取出重复数据.png)]
3.5.1.5 运算查询,查询结果参与运算(没有改变数据库中的数据)
某列数据和固定值运算
SELECT 列名1 + 固定值 FROM 表名;
某列数据和其他列数据参与运算
SELECT 列名1 + 列名2 FROM 表名;
注意: 参与运算的必须是数值类型
需求:
- 添加数学,英语成绩列,给每条记录添加对应的数学和英语成绩
- 查询的时候将数学和英语的成绩相加
实现:
修改student表结构,添加数学和英语成绩列
ALTER TABLE student ADD math INT; ALTER TABLE student ADD english INT;
给每条记录添加对应的数学和英语成绩
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WbF8aixf-1576335235758)(image\添加数学和英语成绩.png)]查询math + english的和
SELECT math + english FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iS6f3hbq-1576335235760)(image\查询math和english的和.png)]
结果确实将每条记录的math和english相加,但是效果不好看
查询math + english的和使用别名”总成绩”
SELECT math + english 总成绩 FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R58SdUsc-1576335235769)(image\组合查询结果取别名.png)]
查询所有列与math + english的和并使用别名”总成绩”
SELECT *, math + english 总成绩 FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8YCQR3Yj-1576335235773)(image\查询所有列数据和参与运算.png)]
查询姓名、年龄,将每个人的年龄增加10岁
SELECT name, age + 10 FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jlWjiIsX-1576335235775)(image\查询后年龄增加10岁.png)]
3.6 条件查询(很重要,含比较,逻辑,范围,模糊像什么匹配通配符)
前面我们的查询都是将所有数据都查询出来,但是有时候我们只想获取到满足条件
的数据
语法格式:SELECT 字段名 FROM 表名 WHERE 条件;
流程:取出表中的每条数据,满足条件的记录就返回,不满足条件的记录不返回
3.6.1 准备数据
CREATE TABLE student4 (id int,name varchar(20),age int,sex varchar(5),address varchar(100),math int,english int
);INSERT INTO student4(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);
3.6.2 比较运算符
>
大于
<
小于
<=
小于等于
>=
大于等于
=
等于,注意一个=!!!
<>
、!=
不等于,有两个,要注意!!!
具体操作:
- 查询math分数大于80分的学生
SELECT * FROM student4 WHERE math>80;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yJnv4tjy-1576335235779)(imgs\where查询01.png)]
- 查询english分数小于或等于80分的学生
SELECT * FROM student3 WHERE english<=80;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-t3irVp5O-1576335235781)(imgs\where查询02.png)]
- 查询age等于20岁的学生
SELECT * FROM student3 WHERE age=20;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ew7X5Uuw-1576335235785)(imgs\where查询03.png)]
- 查询age不等于20岁的学生
SELECT * FROM student3 WHERE age!=20;
SELECT * FROM student3 WHERE age<>20;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UxbFxuT1-1576335235790)(imgs\where查询04.png)]
3.6.3 逻辑运算符,与或非,跟java类似,简单
and
多个条件同时满足,并且
or
多个条件其中一个满足,或者
not
不满足,取反
具体操作:
- 查询age大于35且性别为男的学生(两个条件同时满足)
SELECT * FROM student4 WHERE age>35 AND sex='男';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rthOkOR3-1576335235791)(imgs\where查询05.png)]
- 查询age大于35或性别为男的学生(两个条件其中一个满足)
SELECT * FROM student333 WHERE age>35 OR sex='男';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YtqGnbhe-1576335235793)(imgs\where查询06.png)]
- 查询id是1或3或5的学生
SELECT * FROM student4 WHERE id=1 OR id=3 OR id=5;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fgxlI252-1576335235816)(imgs\where查询08.png)]
in关键字,在()范围里面,可以理解为是或者的优化,或者集合
语法格式:SELECT 字段名 FROM 表名 WHERE 字段 in (数据1, 数据2...);
in
里面的每个数据都会作为一次条件,只要满足条件的就会显示
具体操作:
- 查询id是1或3或5的学生
SELECT * FROM student4 WHERE id IN (1,3,5);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aIpR9LXV-1576335235825)(imgs\where查询08.png)]
- 查询id不是1或3或5的学生, NOT IN,不在()集合范围内
SELECT * FROM student4 WHERE id NOT IN (1,3,5);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4sgwCefP-1576335235826)(imgs\where查询07.png)]
3.6.4 范围,在什么和什么之间,注意包括相等的情况,简单
BETWEEN 值1 AND 值2
表示从值1到值2范围,包头又包尾
比如:age BETWEEN 80 AND 100
相当于: age>=80 && age<=100
具体操作:
- 查询english成绩大于等于75,且小于等于90的学生
SELECT * FROM student4 WHERE english>=75 AND english<=90;
SELECT * FROM student4 WHERE english BETWEEN 75 AND 90;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uso4qxqr-1576335235829)(imgs\where查询09.png)]
3.6.5 like,关键字,像什么,模糊查询,跟通配符一起使用,记忆!!!
LIKE
表示模糊查询
SELECT * FROM 表名 WHERE 字段名 LIKE '通配符字符串';
满足通配符字符串
规则的数据就会显示出来
所谓的通配符字符串
就是含有通配符的字符串
MySQL通配符有两个:
%
: 表示0个或多个字符(任意个字符)
_
: 表示一个字符
具体操作:
- 查询姓马的学生
SELECT * FROM student4 WHERE NAME LIKE '马%';-- 注意用like关键字
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1wFS4HyR-1576335235832)(imgs\where查询10.png)]
- 查询姓名中包含’德’字的学生
SELECT * FROM student4 WHERE NAME LIKE '%德%';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vSbyESWP-1576335235833)(imgs\where查询11.png)]
- 查询姓马,且姓名有三个字的学生
SELECT * FROM student4 WHERE NAME LIKE '马__';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mP9mxZVN-1576335235848)(imgs\where查询12.png)]
MYSQL的安装基础语法笔记相关推荐
- 黑马MYSQL课程的基础语法笔记
今日内容 数据库的基本概念 MySQL数据库软件 安装 卸载 配置 SQL 数据库的基本概念 1. 数据库的英文单词: DataBase 简称 : DB 2. 什么数据库?* 用于存储和管理数据的仓库 ...
- JavaScript脚本语⾔基础语法笔记总结
JavaScript脚本语⾔&基础语法&笔记总结 0.学前准备: JavaScript简介使⽤⽅法 1. JavaScript简介 什么是JavaScript? 前端Web技术的组成: ...
- Python基础语法笔记
文章目录 前言 1.变量.运算符与数据类型 1.1 注释 1.2 运算符 1.3 变量与赋值 1.4 数据类型与转换 1.5 print()函数 2.位运算 2.1 原码.反码和补码 2.2 利用位运 ...
- JAVA基础语法笔记(黑马程序员系列)
1. Java概述 1.1 Java语言发展史(了解) 语言:人与人交流沟通的表达方式 计算机语言:人与计算机之间进行信息交流沟通的一种特殊语言 Java语言是美国Sun公司(Stanford Uni ...
- 01、java基础语法笔记
day01 - java基础语法 1. Java概述 1.1 Java语言发展史(了解) 语言:人与人交流沟通的表达方式 计算机语言:人与计算机之间进行信息交流沟通的一种特殊语言 Java语言是美国S ...
- MySQL概述 -- 安装配置 -- 学习笔记
前言 在我们讲解SpringBootWeb基础知识(请求响应案例)的时候,我们讲到在web开发中,为了应用程序职责单一,方便维护,我们一般将web应用程序分为三层,即:Controller.Servi ...
- MySQL学习之基础语法详解
这篇记录一下MySQL的基础语法 DDL数据定义语言 主要是针对数据库,表,列的操作,即创建,查询,修改,删除 查询所有数据库 show databases; 创建数据库 create databas ...
- JavaScript基础语法笔记,ECMAScript基础,每部分都有经典案例以及解析。会持续更新(2022.0310)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.JavaScript导读 1.1 什么是JavaScript(这里借鉴Js红宝书的内容,看一看就可以了) 1.2 ...
- JavaSE基础语法-笔记
基础语法 注释 1.单单行注释 //Java单行注释 2.多行注释 /*多行注释..... */ 3.文档注释 /**文档注释 */ 标识符 1.关键字 abstract assert boolean ...
最新文章
- 多篇开源CVPR 2020 语义分割论文
- U-Net 3+: 全尺度的跳跃连接的 UNet
- 深度剖析WinPcap之(九)——数据包的发送过程(12)
- linux下用户切换
- 查看安装软件/Select-object/Where-Object xxx -like
- ef 在此上下文中只支持基本类型或枚举类型_Java枚举不应该成为你成功路上得绊脚石,源码给你讲解清楚
- 逻辑与计算机科学之间有什么联系,数学、逻辑与计算机科学的关系
- 学术 | 如何写一篇学术论文?(下)
- mysql基础之mariadb的安装,连接,用户,密码,权限设置语句详解
- CocoaLumberjack+XcodeColor(输出带有颜色的日志)在安装过程中遇到的问题
- 华云数据:以信创云构筑自主创新长城之基
- 怎么做SWOT分析模型PPT呢?
- 获取 个位数 十位数 百位数 千位数
- Linux paste合并文件,使用多个字符作为间隔符
- 桌面、平板、手机和机器人操作系统(ROS)市场占有率数据和趋势分享(附引用2019版)
- screen Attached
- C语言正确的输入格式和输入方式
- Java笨狗的C/C++
- LeetCode 342. 4的幂 附带《Effective C++》pdf版下载
- 多仓库移动机器人时空约束分层调度策略