MySQL数据库基础

MySQL数据库基础

  • 一、数据库的基本概念
    • 1.数据
    • 2.表
    • 3.数据库
    • 4.数据库管理系统(DBMS)
    • 5.数据库系统
  • 二、数据库分两大类
    • 关系数据库
    • 非关系数据库
  • 三、MySQL数据库的基本语句
    • 1.常用的数据类型
    • 2.数据库管理
      • 2.1mysql基础语句操作
        • 2.1.1 设置密码、登录数据库
        • 2.1.2 查看数据库结构
      • 2.2 DDL语句:定义数据中的操作
        • 2.2.1创建数据库和表-creat
      • 2.3 DML语句:管理表中的数据记录
        • 2.3.1 插入数据-insert
        • 2.3.2 删除不需要的数据(表内容)-delete
      • 2.4 DQL语句:查询数据记录-selet
      • 2.5 DCL语句:数据控制语言-alter
        • 2.5.1 修改表名
        • 2.5.2 扩展表结构(增加字段)
        • 2.5.3 修改字段(列)名,添加唯一键
  • 四、总结

一、数据库的基本概念

1.数据

  • 描述事物的符号记录
  • 包括数字,文字、图形、图象、声音、档案记录等
  • 以“记录”形式按统一的格式进行存储

2.表

  • 将不同的记录组织在一起
  • 用来存储具体数据

3.数据库

  • 表的集合,是存储数据的仓库
  • 以一定的组织方式存储的相互有关的数据集合
  • 是按照数据结构来组织、存储和管理数据的仓库

4.数据库管理系统(DBMS)

  • 是实现对数据库资源有效组织、管理和存取的系统软件

数据库的建立和维护功能、数据定义功能、数据操纵功能、数据库的运行管理功能、通信功能

5.数据库系统

  • 是一个人机系统,由硬件、OS、数据库、DBMS、应用软件和数据库用户组成
  • 用户可以通过DBMS或应用程序操作数据库

二、数据库分两大类

关系数据库

  • 关系数据库系统是基于关系模型的数据库系统
  • 关系模型的数据结构使用简单易懂的二位数据表
  • 关系模型可用简单的“实体-关系”(E-R)图来表示
  • E-R图中包含了实体(数据对象)、关系和属性三个要素

MySQL数据库基础_第1张图片

  • 关系数据库的存储结构是二维表格
    • 在每个二维表中
      • 每一行称为一条记录,用来描述一个对象的信息
      • 每一列称为一个字段,用来描述对象的一个属性

非关系数据库

  • 非关系数据库也被称作NoSQL(Not Only SQL)

  • 存储数据不以关系模型为依据,不需要固定的表格式

  • 非关系型数据库的有点

    • 数据库可高并发读写
    • 对海量数据高效率存储与访问
    • 数据库具有高扩展性与可用性
  • 常用的非关系数据库:Redis、mongoDB等

三、MySQL数据库的基本语句

1.常用的数据类型

类型 解释 举例
int 整型 用于定义整数类型的数据(1、2、3、4、5…)
float 单精度浮点(4字节32位) 准确表示小数点后六位
double 双精度浮点(8字节64位) 小数位更多,更精确
char 固定长度的字符类型 定义字符长度(存的少,会补空格,存的多被截取,高版本报错)
varchar 可变长度的字符类型 定义字符最大长度(存的小,总长度变小,存的大于最大,报错)
text 文本
image 图片
decimal(5,2) 总共5个有效长度数字,小数点后面有两位

char和varchar的区别

  • char: 如果存入数据的实际长度比指定长度要小,会补空格指指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错。
  • varchar: 如果存入的数据实际长度比指定长度要小,那么指定长度会变成实际长度一样,如果存入的数据的实际长度大于指定长度,会报错。

截取和截断的区别

  • 截取会对后一位进行四舍五入,截断直接获取要的数字,不进行四舍五入。

2.数据库管理

SQL语言分类

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

2.1mysql基础语句操作

2.1.1 设置密码、登录数据库

mysqladmin -u root -p password "123"   #给数据库设置密码(后面的回车)

mysql -uroot -p "123"   #直接登录数据库
mysql -u root -p        #登录数据库,输入密码后完成登录

2.1.2 查看数据库结构

show databases;     #查看有多少数据库(分号要加)
use mysql           #进入一个数据库中,(分号可以不加)
show tables;        #查看该数据库中有多少个表

MySQL数据库基础_第2张图片

2.1.3 查看表的结构

describe  db;     #查看表的字段属性(可缩写为desc db)

MySQL数据库基础_第3张图片

2.2 DDL语句:定义数据中的操作

  • DDL语句可用于创建数据库对象(库、表、索引)
  • 删除数据库和表

2.2.1创建数据库和表-creat

create database school;     #创建一个名为school的数据库

create table  hj (id int(10) not null,name varchar(40) not null,age int (3) not null,score decimal(5,2) default '0',primary key (id));        
#创建一个名为hj的表,(定义id不为空,名字不为空,年龄不为空,成绩可为空默认为“0”,主键为id)

create table scholl.hj1 (id int(10) not null); # 在任意库中创建school库中的ky21表

MySQL数据库基础_第4张图片

MySQL数据库基础_第5张图片

MySQL数据库基础_第6张图片

2.2.2 删除数据库和表-drop

drop database huang      #删除一个名为huang的数据库

drop table hj2    #删除一个ky22的表
drop table school.hj1    #可以再别的数据库中删除指定数据库中的表

MySQL数据库基础_第7张图片

2.3 DML语句:管理表中的数据记录

2.3.1 插入数据-insert

select * from hj;     #查看hj表中所有的数据
select * from \G;       #友好的显示

insert into hj (id,name,age,score) values(1,'张三',18,88);   
#向hj表中插入数据

insert into hj (id,name,age) values(2,'张五',18);
#向hj表中指定字段插入,(可为空的字段,可以不添加值,为默认值)

insert into hj values(3,'李四',20,67),(4,'赵四',22,90);
#批量添加表中更多数据(前面的字段不写为默认)

MySQL数据库基础_第8张图片

2.3.2 更新原有数据-update

update 表名 set 字段1=字段值1,字段2=字段值10 where 表达式;
update hj set name='小红',age=35 where name='张五';
#将字段name为zhanger的,name和age进行修改。

update hj set name='小明',age=24 where id>2;
#将id大于2的记录进行修改。

MySQL数据库基础_第9张图片

MySQL数据库基础_第10张图片

2.3.2 删除不需要的数据(表内容)-delete

格式:delete from 表名 where 条件表达式;
delete from hj where name='小明';   #删除hj表中name为小明的记录

delete from hj where id>4;         #删除hj表中id大于4的记录

delete from hj;                    #删除hj表中所有记录(谨慎操作)

MySQL数据库基础_第11张图片

2.4 DQL语句:查询数据记录-selet

格式:select 字段1,字段2 from 表名 【where 条件表达式】;
select * from hj;           #查看整个表的所有记录
select id,name from hj;     #查看整个表中的id,name字段
select id,name from hj\G    #友好查看整个表的id,name,
select id,name,score from hj where name='小明';    #查看name为小明的id,namescore
select id,name from hj where score>80;    #查看分数值大于80分的字段id,name ,
select * from hj limit 2;   #查看前二行
select * from hj limit 2,3;    #显示第2行后的3行。(不包括第2行)

MySQL数据库基础_第12张图片

MySQL数据库基础_第13张图片

MySQL数据库基础_第14张图片

MySQL数据库基础_第15张图片

2.5 DCL语句:数据控制语言-alter

2.5.1 修改表名

alter:修改表名称或表结构
格式:alter table 旧表名 rename 新表名;
alter  table  hj rename  yun;
alter  table  yun  rename  hj;

MySQL数据库基础_第16张图片

2.5.2 扩展表结构(增加字段)

alter table  表名  add address varcghar(50) default '江宁区';
#表示在表中增加一个字段为:address字段。

MySQL数据库基础_第17张图片

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

格式:alter table 表名 change 旧列名 新列名 数据类型 【unique key】;
unique key :唯一键(特性:唯一,但可以为空,空值只允许出现一次)
primary key:主键(特性:唯一且非空)
alter table  hj change name name_new varchar(50) unique key;
#change 可以修改字段名、数据类型、约束等所有项

MySQL数据库基础_第18张图片

MySQL数据库基础_第19张图片

2.5.4 删除字段

alter table 表名 drop 字段名;
alter table  hj drop name_new;

MySQL数据库基础_第20张图片

四、总结

sql语言的分类

DDL:数据定义语言,用于创建和删除数据库表等操作

  • create (创建)、drop(删除)

DML:数据操纵语言,用于管理表中的记录,对数据进行增、删、改的操作

  • insert(插入)其中有into(插入)、selete(删除)、update(改)其中为set(修改

DQL:数据查询语言,主要用来查询数据库中的记录

  • select(查看)

DCL:数据控制语言,用来针对字段属性的增、删、改增操作

  • alter(修改字段),其中有add(添加)、change(修改)、drop(删除)

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