数据库优化第二讲(数据库和数据表的操作)

数据库优化

SQL介绍&常见的数据类型

SQL

SQL是结构化查询语言,是一种用来操作RDBMS(关系型数据库管理系统)的数据库语言,当前关系型数据库都支持使用SQL语言进行操作,也就是说可以通过SQL操作oracle,sql server,mysql等关系型数据库。

SQL语句

  • DQL:数据查询语言,用于对数据进行查询,如select
  • DML:数据操作语言,对数据进行增加、修改、删除,如insert、update、delete
  • DDL:数据定义语言,进行数据库、表的管理等,如create、drop
    重点是数据的crud(增删改查),必须熟练编写DQL、DML,能够编写DDL完成数据库、表的操作
    数据完整性

在表中为了更加准确的存储数据,保证数据de正确有效,可以在创建表的时候,为表添加一些强制性的验证,包括数据字段的类型、约束

常见的数据类型

  • 整数:int
  • 小数:decimal
  • 字符串:varchar,char
  • 日期时间:date,time,datetime
  • 枚举类型:enum

特别说明的类型

decimal表示浮点数,如decimal(5,2)表示共存五位数,小数占2位(float也可以)

char表示固定长度的字符串,如char(3),如果填充’ab’时会补一个空格为’ab’,即’ab '。

varchar表示可变长度的字符串,如varchar(3),填充’ab’时就会存储’ab’

字符串text表示存储大文本,当字符大于4000时推荐使用

对于图片、音频、视频等文件,不存储在数据库中,而是上传到某个服务器上,然后在表中存储这个文件的保存路径
更全的数据类型参考:数据类型

数值类型

类型 字节大小 有符号范围(Signed) 无符号范围(Unsigned)
TINYINT 1 -123~127 0~255
SMALLINT 2 -32768~32767 0~65535
MEDIUMINT 3 -8388608~8388607 0~1677215
INT/INTEGER 4 -2147483648~2147483647 0~4294967295
BIGINT 5 -9223372036854775808~9223372036854775807 0~18446744073709551615

字符串

类型 字节大小 示例
CHAR 0~255 类型:char(3)输入‘ab’,实际存储为’ab’,输入’abcd’实际存储为’abc’
VARCHAR 0~255 类型:varchar(3)输入‘ab’,实际存储为’ab’,输入’abcd’实际存储为’abc’
TEXT 0~65535 大文本

日期时间

类型 字节大小 示例
DATE 4 ‘2020-01-01’
TIME 3 ‘12:29:59’
DATETIME 8 ‘2020-01-01 12:29:59’
YEAR 1 ‘2017’
TMESTAMP 4 ‘1970-01-01 00:00:01’ UTC ~ ‘2038-01-01 00:00:01’ UTC

数据库约束

约束

  • 主键primary key:物理上存储的顺序
  • 非空not null:此字段不允许填写空值
  • 惟一unique:此字段的值不允许重复
  • 默认default:当不填写此值时会使用默认值,如果填写时以填写为准
  • 外键foreign key:对关系字段进行约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常

在这里插入图片描述

FIELD 'name' doesn't have a default value # 字段‘name’没有默认值  空的字符串 非空 ''  # 不允许空值

Duplicate entry '1' for key 'card'  # 重复条目

数据库操作

数据库的操作

  • 连接数据库
    mysql -u root -p root
    mysql -uroot -p

  • 退出的数据库
    exit/quit

  • sql语句最后需要有分号;作结尾

  • 显示数据库版本
    select version();在这里插入图片描述

  • 查看所有数据库
    show databases;
    在这里插入图片描述

  • DDL(数据定义语句)

  • 创建数据库
    create database python01;
    create database python01 charset=utf8;
    在这里插入图片描述

  • 查看创建数据库的语句
    show create database python04;
    在这里插入图片描述

  • 查看当前使用的数据库
    select database();
    在这里插入图片描述

  • 使用数据库

  • use 数据库的名字
    use python01;
    在这里插入图片描述

  • 删除数据库

  • drop database 数据库名;
    drop database python01;
    在这里插入图片描述

数据表操作

数据表的操作

  • 查看当前数据库中所有表
    show tables;

  • 创建表

  • auto_increment表示自动增长

  • not null 表示不能为空

  • primary key 表示主键

  • default 默认值

  • create table 数据库表名字(字段 类型 约束[,字段 类型 约束])
    create table demo1 (id int,name varchar(30));

create table demo2(
id int printmary key not null auto_incremen,
name varchar(30)
);

  • 查看表结构

  • desc 数据表的名字;
    desc demo2;
    在这里插入图片描述

  • 创建students表(id、name、age、high、gender、cls_id)
    create table students(
    id int not null primary key auto_increment,
    name varchar(30),
    age tinyint default 18,
    high decimal(5,2),
    gender enum(‘男’,‘女’,‘保密’) default ‘保密’, (存数据的时候只能存 男或女)
    cls_id int
    );
    在这里插入图片描述

  • 无符号:unsigned

  • 创建classes表(id、name)
    create table classes(
    id int primary key not null auto_increment,
    name varchar(30)
    );
    -在这里插入图片描述

  • 查看表的创建语句

  • show create table 表名字;
    show create table students;
    在这里插入图片描述

数据表数据新增

数据表数据修改

  • 修改表-添加字段

  • alter table 表名 add 列名 类型;
    alter table students add birthday date;

  • 修改表-修改字段:不重命名版

  • alter table 表名 modify 列名 类型;
    alter table students modify birthday date default ‘1990-1-1’;

  • 修改表-修改字段:重命名版

  • alter table 表名 change 原名 新名 类型及约束;
    alter table students change birthday birth date default ‘1990-1-1’;

  • 修改表-删除字段

  • alter table 表名 drop 列名;
    alter table students drop high;

  • 删除表

  • drop table 表名;

  • drop database 数据库;

增删改查curd

  • 增加
    –全列插入
    –insert [into] 表名 values(…)
    –向classes表中插入 一个班级
    insert into classes values(1,‘单身班’);

–向classes表插入一个学生信息
在这里插入图片描述
– 主键字段 0 null default 来占位
insert into students values(0,‘居然’,18,‘男’,1,‘1990-1-1’); – id是多少?
insert into students values(null,‘juran’,19,‘男’,1,‘1990-1-1’);
insert into students values(default,‘hanhan’,19,‘男’,1,‘1990-1-1’);

–枚举类型插入 下标是从1开始的
insert into students values(default,‘xiaowang’,19,1,1,‘1990-1-1’);

–部分插入
–insert into 表名(列1,…) values(值1,…) --非空字段
insert into students(
insert into students(‘name’,‘gender’) values(‘xw’,2);
在这里插入图片描述
–多行插入
insert into students values
(default,‘juran’,19,‘男’,1,‘1990-1-1’),
(default,‘666’,20,‘男’,1,‘1990-1-1’);
在这里插入图片描述

课堂总结

在这里插入图片描述

发布了30 篇原创文章 · 获赞 0 · 访问量 688

猜你喜欢

转载自blog.csdn.net/luobofengl/article/details/104356845