MySQL数据库管理

目录

一、mysql概述

二、数据类型

三、char和varchar的区别

四、varchar和text的区别

五、操作案例

连接数据库

查看数据库结构

查看数据库中包含的表

查看表的结构(字段)

SQL语句

SQL语言分类:

DDL数据定义语言:

创建新的数据库

删除指定数据表:

删除指定的数据库:

MDL管理表中的数据记录:

查询数据记录:

修改,更新数据表中的数据记录:

在数据表中删除指定的数据记录:

DQL查询数据记录:

DCL修改表名和表结构:

修改表名:

修改字段名(列),添加唯一键:

删除字段:

一、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位,指定长度数组

注:

(1)设一个字段定义为float(6,3),如果插入一个数123.45678,实际数据库里存的是123.456,但总个数还以实际为准,即6位。整数部分最大是3位,如果插入数12.123456,存储的是12.1234,如果插入12.12,存储的是12.1200。

(2)decimal (5,2),当输入的数值后的小数位小于两位时,会拿0补全两位;当超过两位时,小数点后第三位是自动进行的四舍五入进第二位。

三、char和varchar的区别

(1)char(n)若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。

(2)char(n)固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。

(3)char类型的字符串检索速度要比varchar类型的快。

四、varchar和text的区别

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

(2)text类型不能有默认值。

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

五、操作案例

连接数据库

查看数据库结构

查看数据库中包含的表

查看表的结构(字段)

 

 

  1. USE 数据库名;

  2. DESCRIBE [数据库名.]表名;

  3. 可缩写成:DESC 表名;

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

 

SQL语句

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

SQL语言分类:

DDL数据定义语言,用于创建数据库对象,如库、表、索引等
DML数据操纵语言,用于对表中的数据进行管理
DQL数据查询语言,用于从数据表中查找符合条件的数据记录
DCL数据控制语言,用于设置或者更改数据库用户或角色权限

DDL数据定义语言:

创建新的数据库

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);

主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键

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

删除指定数据表:

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

删除指定的数据库:

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;

MDL管理表中的数据记录:

向数据表中插入新的数据记录
 

INSERT INTO 表名(字段1,字段2[,...]) VALUES(字段1的值,字段2的值,...);
 
例:create database SCHOOL;
 
use SCHOOL;
 
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,'zhangsan',99,PASSWORD('123456'));
insert into CLASS (id,name,score,passwd) values(2,'lisi',88,123456);
 
#PASSWORD('123456'):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。

查询数据记录:

SELECT 字段名1,字段名2[,...] FROM 表名 [WHERE 条件表达式];
 
例:select * from CLASS;
select name,score from CLASS where id=1;

修改,更新数据表中的数据记录:

UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];
 
例:insert into CLASS (id,name,score,passwd) values(3,'wangwu',77,123456);
insert into CLASS (id,name,score,passwd) values(4,'zhaoliu',66,123456);
select * from CLASS;
 
update CLASS set id=5 where name='zhangsan';
select * from CLASS;
 
update CLASS set name='ma',score=100 where id=2;
select * from CLASS;

在数据表中删除指定的数据记录:

DELETE FROM 表名 [WHERE 条件表达式];
 
例:delete from CLASS where id=4;
select * from CLASS;

DQL查询数据记录:

select name from CLASS\G         #以列表方式竖向显示
select * from CLASS limit 2;      #只显示头2行
select * from CLASS limit 2,3;    #显示第2行后的前3行

DCL修改表名和表结构:

修改表名:
ALTER TABLE 旧表名 RENAME 新表名;
 
例:alter table CLASS rename CLASS3;
show tables;
select * from CLASS3;

修改字段名(列),添加唯一键:

ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];
 
例:alter table CLASS3 change name student_name varchar(20) unique key;
select * from CLASS3;
 
例:insert into CLASS3 (id,name,score,passwd) values(1,'zhangbin',250,123456);
select * from CLASS3;
insert into CLASS3 (id,name,score,passwd) values(6,'zhangbin',250,123456);

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

删除字段:

ALTER TABLE 表名 DROP 字段名;
 
例:alter table CLASS3 drop score;

  • 47
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值