本篇是在已下载Mysql的情况下进行的,若还未下载或未创建Mysql服务,请转到这篇:
2024 年 MySQL 8.0.40 安装配置、Workbench汉化教程最简易(保姆级)_mysql8.0.40下载安装教程-CSDN博客
本文对于mysql的操作均使用控制台sql原生代码编写
目录
一、MySQL背景介绍
MySQL 是一种广泛使用的关系型数据库管理系统(RDBMS),以其高性能、可靠性和易用性而闻名。作为开源软件,MySQL 遵循 GNU 通用公共许可证(GPL),提供免费和商业版本,适用于各种规模的应用程序开发。它支持多种操作系统,如 Windows、Linux 和 macOS,具有跨平台的灵活性。MySQL 的核心优势在于其高效的查询处理能力,特别适合高并发读写操作,并且内置了丰富的安全特性,如用户权限管理和 SSL 支持,确保数据传输的安全性。此外,MySQL 提供多种存储引擎选择,如 InnoDB 和 MyISAM,以满足不同的应用场景需求。它的广泛应用涵盖了从简单的网站到复杂的企业级应用,包括内容管理系统(CMS)、电子商务平台和大数据分析等。活跃的社区支持和丰富的生态系统使得 MySQL 成为开发者首选的数据库解决方案之一。Oracle 公司自2010年起拥有 MySQL,但其开源版本继续受到全球开发者的青睐和支持。
二、Mysql基本操作
1、运行Mysql
方法一:
直接软件包中自带登录客户端
data:image/s3,"s3://crabby-images/8dccf/8dccf6c8533fca4293ff15e8958d30a0e7019099" alt=""
输入之前下载mysql时输入的密码,点击Enter(设置密码可以看之前这篇:
2024 年 MySQL 8.0.40 安装配置、Workbench汉化教程最简易(保姆级)_mysql8.0.40下载安装教程-CSDN博客)
data:image/s3,"s3://crabby-images/f925d/f925d29246179f7b6109119558dbed1e09f19ed9" alt=""
最左边出现mysql>即代表已进入mysql
方法二:
在cmd终端中进入到mysql文件中的bin目录
依次输入命令:
D:
cd D:load_softwareMysql8.0MySQL Server 8.0Installin
如下图:
data:image/s3,"s3://crabby-images/49338/49338f3b6a0a13650dd9c742d2c989a9f3c401fc" alt=""
输入mysql的进入命令
mysql -uroot -p
这里的p后面加root代表显示输入密码,若不加则默认隐藏密码
输入密码后成功进入页面如下:
data:image/s3,"s3://crabby-images/d6a85/d6a85e59e458243e5d39cb5bbe7fb0ca34f53a25" alt=""
注意!在mysql>目录下,输入的语句必须以";"结尾才可运行!
2、修改密码
在mysql>下输入:
ALTER USER 'root'@'localhost' IDENTIFIED BY '718718';
若是在其他设备和端口,则修改root和localhost即可。
8.0以上版本的直接输入下面语句即可:
set password = '';
3、显示、创建和删除数据库
显示
在mysql>目录下输入
show databases;
可以显示目前该数据库服务上所安装的数据库文件,当然,大家的页面和我肯定不一样:
data:image/s3,"s3://crabby-images/fb419/fb419a7c6d0331b0c27eba53cacf000c9a3f6b36" alt=""
创建数据库
在mysql目录下输入:
create database test default character set utf8;
(default character set设置默认编码关键字,test是数据库名称)
再次显示数据库,发现test数据库已加入:
data:image/s3,"s3://crabby-images/83d09/83d095749e35d44995bd61c741900aa8fde44d29" alt=""
删除数据库
输入以下命令即可(test替换成自己要删除的数据库名称):
drop database test;
三、数据库的基本语句
数据库,我的理解是在一个文件夹中放了很多excel表
首先,进入到一个数据库中:
use test;
data:image/s3,"s3://crabby-images/f9a09/f9a09c334af0c65d1526371b75992a6dc01ee339" alt=""
查看该数据库中的所有数据表:
show tables;
可以看到现在还是空的
data:image/s3,"s3://crabby-images/58f27/58f276f4f1c2395d70341ee6fdc54523aacb2de9" alt=""
1、基础数据类型
整数:
data:image/s3,"s3://crabby-images/ec66e/ec66e3490f9f16c44ceaf909551115b00e3e3d9e" alt=""
小数:
data:image/s3,"s3://crabby-images/52cc7/52cc733bcc710fa3c241192bd9d9bc15c760756d" alt=""
decimal是精确小数,double和float和decimal用法相似
字符串:
data:image/s3,"s3://crabby-images/d1d13/d1d13c0ce8762359587be82ae6b1601e49e797c7" alt=""
data:image/s3,"s3://crabby-images/93578/93578897475189b8a84bbe52ac8d171ee9ff8a45" alt=""
data:image/s3,"s3://crabby-images/75eb1/75eb1973b8d790e9a398b11f1a0bbc8c86b5789a" alt=""
时间类型:
data:image/s3,"s3://crabby-images/b98fe/b98fe507436aec66e1f98942f7f86962c8065902" alt=""
2、创建表:
data:image/s3,"s3://crabby-images/03ad4/03ad4620c489e5a58cdf7d3319170dbc74259fd2" alt=""
设置主键一般为非空,并且可以自增(默认也是非空,可以不写not null)
MySQL还有很多其他的数据类型,例如:set、enum、TinyBlob、Blob、MediumBlob、LongBlob等,详细见官方文档:
简单的创建:
create table tb1(id int not null primary key auto_increment,name varchar(64))DEFAULT CHARSET=utf8;
这里的primary key auto_increment是设置主键,并且自动加一
data:image/s3,"s3://crabby-images/e0df2/e0df2acd84b78b9956522a532abbea9a90e8cf22" alt=""
这样创建可视性不高,也可以分行,只要不加";"就不会运行:
create table tb2(
age int,
salary tinyint
)DEFAULT CHARSET=utf8;
data:image/s3,"s3://crabby-images/9bb1a/9bb1a6b5e0f167649bb7a818b7c3061804f65ae9" alt=""
查看数据库下创建的表:
show tables;
data:image/s3,"s3://crabby-images/e123b/e123b5148fb8a45cf33dfba4d8af0e4ad9ca0644" alt=""
查看表属性:
desc tb1;
(这里的desc全称是descript)
data:image/s3,"s3://crabby-images/871af/871af4a684e7b91596b6e40132c212a2bf19b112" alt=""
查看表内容:
select * from tb1;
(*号表示全部)
现在还是空表
data:image/s3,"s3://crabby-images/3e9e6/3e9e635eb6f4b94516f7da169eaf5614f45daae3" alt=""
添加内容
insert into 表名(列名,...) values(值,...);
data:image/s3,"s3://crabby-images/942f2/942f2640e1f3c40a1db41816cd77a5eee40562fe" alt=""
也可以一次存入多组数据
insert into 表名(列名,...) values(值,...),(值,...),(值,...)...;
显示:
data:image/s3,"s3://crabby-images/7d645/7d645ac9324dad192ce8e3ebacd1566a3fe187ca" alt=""
由于前面设置了主键为auto_increment,序号会自动加一
查看表属性:
desc 表名
data:image/s3,"s3://crabby-images/77266/77266758e77bdff262da4876110c85e1b267c302" alt=""
删除表:
drop table 表名;
data:image/s3,"s3://crabby-images/760c9/760c970f166f651b686bb73e4925120c765c5770" alt=""
3、表内的增删改查
增加数据
#在表中为某两列插入一行数据
insert into 表名(列名,列名)values(值,值);
#在表中为某几列插入任意行数据
insert into 表名(列名,列名...)values(值,值...),(值,值...),(值,值...),
(值,值...)...;
删除数据
#删除整张表
delete from 表名;
删除表中满足条件的表
delete from 表名 where 条件;
#例子
delete from tb2;
delete from tb2 where id=1;
delete from tb2 where id =1 and name="谭sir";
delete from tb2 where id =2 or name="林sir";
delete from tb2 where id>1;
delete from tb2 where id >= 2;
delete from tb2 where id != 3;
delete from tb2 where id in(l,3);
修改数据
#更新某一列为某值
update 表名 set 列=值;
#更新几列的值
update 表名 set 列=值,列=值...;
#更新满足
update 表名 set 列=值 where 条件;
#例子
update tb2 set password="哈哈哈";
update tb2 set email="哈哈哈"where id >1;
update tb2 set age=age+10 where id>2;
查找数据
#查询整张表
select *from 表名称;
#查询满足条件的列
select 列名称,列名称 from 表名称;
select 列名称,列名称 from 表名称 where 条件;
#例子
select *from tb2;
select id,name from tb2;
select id,name from tb2 where id>10;
select id,name from tb2 where name="xx" and password="xx";
小结
由上文很容易看出,创建数据库和数据表结构,使用原生代码很容易实现,需要提前通过工具+命令创建。
但是,为表中添加数据,若数据量很大时,一行一行添加很不现实,这种情况下一般使用程序来实现增删改查。
四、Mysql综合实例
综合使用所有数据类型创建一个表
创建表:
create table tb2(
id int not null primary key auto_increment,
name varchar(64) not null,
password char(64) not null,
email varchar(64) not null,
age tinyint,
salary decimal(10,2),
ctime datetime
)DEFAULT CHARSET=utf8;
data:image/s3,"s3://crabby-images/9635d/9635d31aa25639f0c5f262dbcd487af6a039cc35" alt=""
插入数据
为该表插入一行内容并显示:
insert into tb2(name,password,email,age,salary,ctime) values("谭sir","123","122685@qq.com",19,100000.20,"2024-12-20 10:02:02");
select * from tb2;
data:image/s3,"s3://crabby-images/e9ed3/e9ed350d52e0b3ef487d99ad31e885de81a9ef15" alt=""
为表中添加多行数据并显示:
#插入数据
insert into tb2(name,password,email,age,salary,ctime)
values("江sir","1203","122685@qq.com",22,0.23,"2024-12-20 10:02:03"),
("林sir","12003","12285@qq.com",19,234.20,"2024-12-20 10:02:03"),
("徐sir","1230","1285@qq.com",18,12345.20,"2024-12-20 10:02:03"),
("张sir","1023","12685@qq.com",18,23456.20,"2024-12-20 10:02:03"),
("叶sir","1203","12265@qq.com",19,34567.20,"2024-12-20 10:02:03");
#显示
select * from tb2;
data:image/s3,"s3://crabby-images/4d6c8/4d6c8bb58e1859d942bc8e384f03e30ec36e996a" alt=""
删除指定数据
(这里好不容易添加了数据,我就少删点)
#删除id为3的数据
delete from tb2 where id=3;
#显示
select * from tb2;
data:image/s3,"s3://crabby-images/5739b/5739b14bdd2d150d0cda693d4764531dd554ad1d" alt=""
修改数据
修改一整列
#更新密码
update tb2 set password="12@qq.com"
#显示
select * from tb2;
data:image/s3,"s3://crabby-images/76022/760221fcd51f583b7c2f597f1ac9c5fb98bc2324" alt=""
带条件修改
#更新id大于1的
update tb2 set email='哈哈哈' where id>1;
#更新id大于2的年龄加一
update tb2 set age=age+1 where id>2;
data:image/s3,"s3://crabby-images/42696/426967f63be0ca863cf7a8631824f18cc8d8ee96" alt=""
查找数据
查找某两列
select id,name from tb2;
data:image/s3,"s3://crabby-images/eff3d/eff3dd49d1fbb959eb8b75ce78330d81f9ed6777" alt=""
查找满足条件的数据
select id,name,password from tb2 where name="谭sir" and age>18;
data:image/s3,"s3://crabby-images/db775/db77538c9f43d44832cdadce75cb1e3355fc03ad" alt=""
本文基于控制台命令,命令繁琐,可视化不太方便,市面上也有一些控制MySQL的软件,后面可能会出新文介绍。还有Python程序存数据进库,也会更新,大家静待。。。
感谢您的三连!!!