MySQL

MySQL的基本操作

文章目录

  • MySQL的基本操作
      • 一、数据库的基本操作
        • 1.数据库结构
        • 2.常用数据类型
          • char和varchar的区别
      • 二、查看数据库的操作
        • 1.进入数据库
        • 2.查看当前服务器中的数据库
        • 3.查看数据库中包含表
        • 4.显示表的结构(字段)
        • 5.查看mysql版本
      • 三、数据库管理-SQL语句
        • 1.创建及删除数据库和表
          • 1.1创建新表
          • 1.2删除指定数据表
          • 1.3删除指定的数据库
        • 2.DML管理表中的数据记录
          • 2.1向数据表中插入新的数据记录
          • 2.2查询数据记录
          • 2.3修改、更新数据表中的数据记录
          • 2.4在数据表中删除指定的数据记录
        • 3.DQL查询数据记录
        • 4.DCL修改表名和表结构
          • 4.1修改表名
          • 4.2扩展表结构(增加字段)
          • 4.3修改字段(列)名,添加唯一键
          • 4.4删除字段
        • 5.扩展
      • 总结

前言:在目前庞大的互联网中,MySQL依然是最为流行的关系型数据库管理系统,通过以下内容,简单介绍了MySQL的一些命令使用方法,快速上手操作MySQL数据库

一、数据库的基本操作

1.数据库结构

数据库–>数据表–>行(记录):用来描述一个对象的信息

​ 列(字段):用来描述对象的一个属性

MySQL数据库的数据文件存放在/usr/local/mysq1/data目录下,每个数据库对应一个子目录,
用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为“. frm"、" .MYD"和“.MYI"。

MYD"文件是MyISAM存储引擎专用,存放MyISAM表的数据。
每一个MyISAM表都会有一个“.MYD”文件与之对应,同样存放于所属数据库的文件夹下,和“.frm" 文件在一起。

”.MYI"文件也是专属于MyISAM 存储引擎的,主要存放MyISAM表的索引相关信息。对于MyISAM

存储来说,可以被cache的内容主要就是来源于“.MYI"文件中。每一个MyISAM表对应一个“.MYI"文件,存放于位置和“. frm"以及“.MYD”一样。

MyISAM存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件( frm, myd,myi)。每个表都有且仅有这样三个文件做为MyISAM存储类型的表的存储,也就是说不管这个表有多少个索引,都是存放在同一个.MYI文件中。

另外还有“. ibd"和ibdata 文件,这两种文件都是用来存放Innodb数据的,之所以有两种文件来存放Innodb的数据(包括索引),是因为Innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是独享表空间存放存储数据。
独享表空间存储方式使用“. ibd"文件来存放数据,且每个表一个“.ibd"文件,文件存放在和MyISAM数据相同的位置。如果选用共享存储表空间来存放数据,则会使用ibdata文件来存放,所有表共同使用一个(或者多个,可自行配置) ibdata 文件。
2.常用数据类型
int:整型
float:单精度浮点4字节32位
double:双精度浮点8字节64位
char:固定长度的字符类型
varchar:可变长度的字符类型
text:文本
image:图片
decimal(5,2):5个有效长度数字,小数点后面有2位	指定长度数组
#Char如果存入数据的实际长度比指定长度要小,会补空格至指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错
char和varchar的区别

区别一,定长和变长及读取速度

char表示固定长度的字符类型,varchar表示可变的字符类型;char如果插入的长度小于定义长度时,则用空格填充;varchar小于定义长度时,还是按实际长度存储,插入多长就存多长的字符。

因为字符长度固定,char的存取速度会比varchar快的多,方便程序的存储及查找,但char也因位长度固定,会占用多余的空间;varchar则由于长度不固定,存取速度慢,但因为字符长度按实际存储,不会占用空间

区别二、存储容量不同

char:最多存放字符个数255,与编码无关

varchar:最多能存放65532个字符,varchar的最大有效长度由最大行大小和使用的字符集确定,整体最大长度是65532字节

varchar和text的区别

①、varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节

②、text类型不能有默认值

③、varchar可直接创建索引,text创建索引要指定前多少个字符,varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用

二、查看数据库的操作

show databases 查看有哪些表

use mysql 进入该用户表

show tables 查看表

describe user 查看显示数据的表结构

1.进入数据库
mysql -uroot -p		下面输入的密码是加密的,
mysql -uroot -p123456		通过这种方式进入数据库,密码明文形式,风险性较高

MySQL_第1张图片
MySQL_第2张图片
MySQL_第3张图片

2.查看当前服务器中的数据库
大小写不区分,分号";"表示结束
SHOW DATABASES	#大部分SQL操作命令必须以";"结束,

MySQL_第4张图片

3.查看数据库中包含表
USE 数据库名;
SHOW TABLES;

#示例1
use mysql
show tables;

MySQL_第5张图片

4.显示表的结构(字段)
USE 数据库名;
SHOW TABLES;

#示例1
use mysql
desc user;

MySQL_第6张图片

显示数据表的结构(字段)

参数 说明
Faile 字段名称
type 数据类型
Null 是否允许为空
Key 主键
Default 默认值
Extra 扩展属性,例如:标志符列(标识了种子,增量/步长)1 2
id 1 3 5 7

方法二:加\G
MySQL_第7张图片

示例二:使用绝对路径查看
MySQL_第8张图片

5.查看mysql版本
#在mysql内查看mysql版本
select version();

#在linux系统中查看mysql版本
mysql -V

在mysql内查看MySQL版本
MySQL_第9张图片
在这里插入图片描述

三、数据库管理-SQL语句

SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理功能

SQL语句分类

语句 详细说明
DDL 数据定义语言,用于创建数据库对象,如库、表、索引等(create)
DML 数据操纵语言,用于对表中的数据进行管理(insert 、drop 、delete 、update)
DQL 数据查询语言,用于从数据表中查找符合条件的数据记录(select)
DCL 数据控制语言,用于设置或者更改数据库用户或角色权限(grant)
1.创建及删除数据库和表
创建新的数据库
CREATE DATABASE 数据库名;

MySQL_第10张图片

1.1创建新表
创建新的表
CREATE TABLE 表名(字段1 数据类型,字段2 数据类型[……][,PRIMARY KEY (主键名)];
主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键

例:create database ky19;
use ky19;
create table wang (id int NOT NULL,name char(10) NOT NULL, score decimal(5,2), passwd char(48) DEFAULT'',PRIMARY KEY (id));

MySQL_第11张图片
MySQL_第12张图片

1.2删除指定数据表
DROP TABLE [数据库名.]表名;       #如不用USE进入库中,则需加上数据库名

MySQL_第13张图片

1.3删除指定的数据库
DROP DATABASE 数据库名;

例:CREATE DATABASE SCHOOL;
use SCHOOL;
CREATE TABLE CLASS (id int NOT NULL,name char(10) NOT NULL,PRIMARY KEY (id));
show databases;
drop table SCHOOL.CLASS;(不用use进入库需要加上库名)
use SCHOOL;
show tables;

drop database SCHOOL;
show databases;

MySQL_第14张图片
MySQL_第15张图片

2.DML管理表中的数据记录
2.1向数据表中插入新的数据记录

选用wenzheng库,里面的zhoubopi表
MySQL_第16张图片

INSERT INTO 表名(字段1,字段2[,...]) VALUES(字段1的值,字段2的值,...);

例:create database SCHOOL;

use SCHOOL;

create table zhoubopi (id int NOT NULL,name char(10) NOT NULL, score decimal(5,2), passwd char(48) DEFAULT'',PRIMARY KEY (id));

insert into zhoubopi (id,name,score,passwd) values(1,'dahua',100,PASSWORD('123456'));
insert into zhoubopi (id,name,score,passwd) values(2,'mawuzi',80,123456);

#PASSWORD('123456'):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。

MySQL_第17张图片

2.2查询数据记录
SELECT 字段名1,字段名2[,...] FROM 表名 [WHERE 条件表达式];

例:select * from zhoubopi;
SELECT name,score FROM zhoubopi where id=1;

MySQL_第18张图片

2.3修改、更新数据表中的数据记录
UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];

例:insert into zhoubopi (id,name,score,passwd) value(3,'banshao',88,123456);
	insert into zhoubopi (id,name,score,passwd) value(4,'erge',66,123456);
	select * from zhoubopi;

	update zhoubopi set id=5 where name='mawuzi';
	select * from zhoubopi;
	
	update zhoubopi set name=haiming score=59 where id=3;
	select * from zhoubopi;

MySQL_第19张图片
MySQL_第20张图片

2.4在数据表中删除指定的数据记录
DELETE FROM 表名 [WHERE 条件表达式];

例:delete from zhoubopi where id=3;
select * from zhoubopi;

MySQL_第21张图片

3.DQL查询数据记录
select name from zhoubopi\G
select * from zhoubopi limit 2;
select * from zhoubopi limit 2,2;

MySQL_第22张图片
MySQL_第23张图片

4.DCL修改表名和表结构
4.1修改表名
ALTER TABLE 旧表名 RENAME 新表名;

例:alter table zhoubopi rename dingpz;
	show tables;
	select * from dingpz;

MySQL_第24张图片

4.2扩展表结构(增加字段)
 ALTER TABLE 表名 ADD address varchar(50) default '不够细';

#default ‘地址不详’:表示此字段设置默认值 地址不详;可与 NOT NULL 配合使用

例: alter table dingpz add address varchar(50) default '不够细';

MySQL_第25张图片

4.3修改字段(列)名,添加唯一键
ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];

例:alter table dingpz change name qietou_name varchar(20) unique key;
	select * from dingpz;
	
	ALTER TABLE 表名 DROP 字段名;

例:alter table dingpz drop score;
	select * from dingpz;
	insert into dingpz (id,qietou_name,passwd) values(1,'xuyang',123456);

MySQL_第26张图片
MySQL_第27张图片
MySQL_第28张图片

每个表中只能由一个主键 ,但是许多内容都需要唯一性,这就是唯一键的作用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LHQVqksZ-1655301226789)(C:/Users/Hanxu/AppData/Roaming/Typora/typora-user-images/image-20220614211043932.png)]

4.4删除字段
ALTER TABLE 表名 DROP 字段名;

例:alter table dingpz DROP score;

MySQL_第29张图片

5.扩展
例:use SCHOOL;
create table if not exists zhoubopi (id int(4) zerofill primary key auto_increment,student_name varchar(20) not null,cardid varchar(18) not null unique key,hobby varchar(50));

desc CLASS4;

MySQL_第30张图片

参数 说明
if not exists 表示检测要创建的表是否已存在,如果不存在就继续创建
int(4) zerofill 表示若数值不满4位数,前面用"0"填充,例如0001
auto_increment 表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;自增长字段数据不可以重复,自增长字段必须是主键;如添加的记录数据没有指定此字段的值且添加失败也会自动递增一次
unique key 表示此字段唯一键约束,此字段数据不可以重复,一张表中只能有一个主键,但是一张表中可以有多个唯一键
not null 表示此字段不允许为NULL

MySQL_第31张图片
MySQL_第32张图片

总结

上述内容简单介绍了mysql的概述以及一些基本的增删改查命令,介绍了SQL语句(DDL、DML、DQL、DCL)的一些简单用法

你可能感兴趣的:(mysql,数据库)