目录
前言:MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 应用软件之一。在本篇中,会让大家快速掌握 MySQL 的基本操作,并轻松使用 MySQL 数据库。
一、mysql概述
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 文件。
二、常见的数据类型
类型 | 说明 |
int | 整形(定义整数类型数据) |
float | 单精度浮点。4字节32位。准确到小数点后六位 |
double | 双精度浮点。8字节64位 |
char | 固定长度的字符类型,定义字符类数据,不足的空格补齐 |
varchar | 可变长度的字符类型 |
text | 文本 |
image | 图片 |
decimal(5,2) | 5个有效长度数字,小数点后面有2位,指定长度数组 |
设一个字段定义为float(6,3),如果插入一个数123.45678,
实际数据库里存的是123.456,但总个数还以实际为准,即6位。
整数部分最大是3位,如果插入数12.123456,存储的是12.1234,如果插入12.12,存储的是12.1200。
decimal (5,2),当输入的数值后的小数位小于两位时,会拿0补全两位;
当超过两位时,小数点后第三位是自动进行的四舍五入进第二位
1、char和varchar的区别
- char(n)若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。
- char(n)固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。
- char类型的字符串检索速度要比varchar类型的快。
2、varchar和text的区别
- varchar可指定n, text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节。
- text类型不能有默认值。
- varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用。
3、进入数据库
mysql -u root -p
三、数据库的结构
1、查看当前服务器中的数据库
mysql> show databases; #大小写不区分,分号“;”表示结束
2、查看数据库中包含的表
use 库名 #进入某个数据库
desc 表名; #查看表内内容 DESCRIBE [数据库名.]表名;
或 desc 表名\G #不用加分号;查看其结构
Field | 字段名称 |
type | 数据类型 |
Null | 是否允许为空 |
key | 主键 |
Default | 默认值 |
Extra | 扩展属性,例如:标志符列(标识了种子,增量/步长)1 2 |
id | 1 3 5 7 |
四、SQL语句
SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。
SQL语言分类:
DDL | 数据定义语言,用于创建数据库对象,如库、表、索引等 |
DML | 数据操纵语言,用于对表中的数据进行管理 |
DQL | 数据查询语言,用于从数据表中查找符合条件的数据记录 |
DCL | 数据控制语言,用于设置或者更改数据库用户或角色权限 |
1、DDL 数据定义语言
1.1、创建新的数据库
CREATE DATABASE 数据库名;
1.2、创建新的表
CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。
例:create database test;
use test;
create table liy (id int NOT NULL,name char(10) NOT NULL, score decimal(5,2), passwd char(48) DEFAULT'',PRIMARY KEY (id));
#NOT NULL 不允许为空值
#DEFAULT默认值为空
#PRIMARY KEY :主键一般选择没有重复并且不为空值的字段
#创建一个xy01表,字段名为fruits数据类型为字符型不能为空并指定其为主键;字段名为price并指定数据类型与长度
desc liy;
1.3、删除指定的数据表
DROP TABLE [数据库名.]表名; #如不用USE进入库中,则需加上数据库名
1.4、删除指定的数据库
DROP DATABASE 数据库名;
例:CREATE DATABASE ceshi;
use SCHOOL;
CREATE TABLE ceshi (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 ceshi;
show databases;
2、DML 管理表中的数据记录
2.1、向数据表中插入新的数据记录
INSERT INTO 表名(字段1,字段2[,...]) VALUES(字段1的值,字段2的值,...);
例:create database test1;
use test1;
create table CLASS (id int NOT NULL,name char(10) NOT NULL, score decimal(5,2), passwd char(48) DEFAULT'',PRIMARY KEY (id));
insert into CLASS (id,name,score,passwd) values(1,'yong',90,PASSWORD('123456'));
insert into CLASS (id,name,score,passwd) values(2,'ly',88,123456);
#PASSWORD('123456'):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。
2.2、查询数据记录
SELECT 字段名1,字段名2[,...] FROM 表名 [WHERE 条件表达式];
例:select * from liy;
select name,score from CLASS where id=1;
2.3、修改、更新数据表中的数据记录
UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];
例:insert into CLASS (id,name,score,passwd) values(3,'bin',77,123456);
insert into CLASS (id,name,score,passwd) values(4,'xu',66,123456);
select * from liy;
update liy set id=5 where name='zhangsan';
select * from CLASS;
update liy set name='ly',score=100 where id=2;
select * from liy;
2.4、在数据表中删除指定的数据记录
DELETE FROM 表名 [WHERE 条件表达式];
例:delete from CLASS where id=5;
select * from CLASS;
3、DQL数据查询语言
select name from CLASS\G #以列表方式竖向显示
select * from liy limit 2; #只显示头2行
select * from liy limit 2,3; #显示第2行后的前3行
因为表中一共只有3行,所以只显示了一行数据
4、DCL 修改表名和表结构
4.1、修改表名
ALTER TABLE 旧表名 RENAME 新表名;
例:alter table liy rename lyong;
show tables;
select * from lyong;
4.2、扩展表结构(增加字段)
ALTER TABLE 表名 ADD address varchar(50) default 'null';
#default ‘地址不详’:表示此字段设置默认值 地址不详;可与 NOT NULL 配合使用
例:alter table lyong add address varchar(50) default 'null';
4.3、修改字段(列)名,添加唯一键
ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];
例:alter table lyong change name student_name varchar(20) unique key;
select * from lyong;
例:insert into lyong (id,name,score,passwd) values(1,'zhangbin',250,123456);
select * from lyong;
insert into CLASS3 (id,name,score,passwd) values(6,'zhangbin',250,123456);
每个表中只能由一个主键 ,但是许多内容都需要唯一性,这就是唯一键的作用
4.4、删除字段
ALTER TABLE 表名 DROP 字段名;
例:alter table lyong drop score;
5、扩展
例:use lly;
create table if not exists CLASS4 (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 lly;
if not exists | 表示检测要创建的表是否已存在,如果不存在就继续创建 |
int(4) zerofill | 表示若数值不满4位数,则前面用“0”填充,例0001 |
auto_increment | 表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且添加失败也会自动递增一次 |
unique key | 表示此字段唯一键约束,此字段数据不可以重复;一张表中只能有一个主键, 但是一张表中可以有多个唯一键 |
not null | 表示此字段不允许为NULL |
五、总结
本篇主要讲述了mysql的概述以及基本的操作命令,介绍了sql的语句,和数据的常用类型介绍。
原文链接:https://blog.csdn.net/weixin_56270746/article/details/125284313
此处评论已关闭