MySQL数据库1—数据库简介与基本使用 原创

1191-杨同学

发表文章数:32

首页 » MySQL » 正文

MySQL数据库

数据库简介

数据存储

  1. 结绳记事——>甲骨文——>图书
  2. 传统数据记录方式的缺点:不易保存;备份困难;查找不便
  3. 现代化手段:文件
    (1)使用简单,例如python中的open可以打开文件,用read/write进行读写,close关闭文件;
    (2)对于数据容量比较大的数据,增删查找比较困难,且性能较差;
    (3)不易扩展。
  4. 现代化手段:数据库
    (1)持久化存储(一种特殊文件,存储在硬盘上);
    (2)读写速度极高;
    (3)保证数据的有效性;
    (4)对程序支持性比较好,容易扩展。

数据库

数据库就是一种特殊的文件,其中存储着需要的数据(需要特数软件进行操作)。
MySQL数据库1---数据库简介与基本使用                    原创
关系型数据库核心元素(表之间存在关系):

  1. 数据库中,每行称为一个记录
  2. 每列称为一个字段(能够唯一标记记录的字段称为主键,如id);
  3. 数据表是数据行的集合,数据库是数据表的集合。
    类比Excel,每个数据库中可以有多个数据表:
    MySQL数据库1---数据库简介与基本使用                    原创

RDBMS

  1. 全称:Relational Database Management System(关系型数据库管理系统)
  2. 当前主要使用两种类型的数据库:关系型数据库和非关系型数据库。所谓的关系型数据库RDBMS,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
  3. 关系型数据库的主要产品:oracle、mysql、ms sql server、sqlite
  4. RDBMS和数据库的关系:
    MySQL数据库1---数据库简介与基本使用                    原创
    C/S架构

SQL

SQL是结构化查询语言(Structured Query Language),是一种来操作RDBMS的数据库语言,当前的关系型数据库都支持使用SQL语言进行操作,SQL语言不区分大小写。
MySQL数据库1---数据库简介与基本使用                    原创

MySQL简介

  1. MySQL是一个关系型数据库管理系统。
  2. 使用C和C++编写,并使用了多种编译语言进行测试,保证源代码的可移植性;
  3. 支持多种操作系统,如linux、windows等;
  4. 支持多线程,充分利用CPU资源;
  5. 开源免费。

MySQL安装

  1. 安装服务器端
    sudo apt-get install mysql-server
  2. 启动服务
    sudo service mysql start
  3. 停止服务
    sudo service mysql stop
  4. 重启服务
    sudo service mysql restart
  5. 配置文件目录为/tec/mysql/mysql.cnf
  6. 图形化界面客户端navicat

数据完整性

一个数据库就是一个完整的业务单元,可以包含多张表,数据被存储在表中;在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表增加一些强制性的验证,包括数据字段的类型、约束

数据类型

使用数据类型的原则:够用就行,尽量使用取值范围小的,而不用大的,这样可以更多的节省存储空间。
常用的数据类型如下:

  1. 整数:int、bit(二进制)
  2. 小数:decimal
  3. 字符串:varchar、char
  4. 日期时间:date、time、datetime
  5. 枚举类型:enum
    MySQL数据库1---数据库简介与基本使用                    原创
    约束
    MySQL数据库1---数据库简介与基本使用                    原创

MySQL数据库1---数据库简介与基本使用                    原创

数据库操作

  1. 链接数据库
mysql -uroot -p  
mysql -uroot -pmysql  # -u后是用户名,-p后是密码
  1. 退出数据库
exit
quit
ctrl+d

sql语句最后需要以分号结尾
3. 显示数据库版本

select version();   # 以分号结尾!
  1. 显示时间
select now();
  1. 查看所有数据库
show databases;
  1. 创建数据库
create database python01;   # 默认拉丁文
create database python02 charset=utf8;  # 支持中文
  1. 查看创建数据库
show create database python05;
  1. 查看当前使用的数据库
select database();
  1. 使用数据库
use python01;
  1. 删除数据库
drop database python01;

数据表的基本操作

  1. 查看当前数据库中所有表
show tables;
  1. 创建数据表
    create table 数据表名字 (字段 类型 约束[, 字段 类型 约束]);
# 常用约束:
# auto_increment 表示自动增长
# not null 表示不能为空
# primary key 表示主键
# default 默认值

use python01;
create table students(
id int unsigned not null auto_increment primary key,
name varchar(30),
age tinyint unsigned default 0,
high decimal(5,2),
gender enum("男", "女", "中性", "保密") default "保密",
cls_id int unsigned
);
  1. 修改表–添加字段
alter table students add birthday datetime;
  1. 修改表–修改字段
alter table students modify birthday date;  # 不重命名
alter table students change birthday birth date default "2020-01-01" ; # 重命名
  1. 修改表–删除字段
alter table students drop high;
  1. 删除表
drop table students;
  1. 查看表结构信息
desc students;

数据表中数据的增删改查(curd)

curd解释:创建(Create)、更新(Update)、读取(Retrieve)、删除(Delete)
1. 增加数据
说明:
(1)主键列自动增长,但是在一个记录(一整行,即全部列)插入时需要占位,通常使用0或者default或者null来占位,插入成功后以实际数据为准;
(2)全记录插入:值的顺序与表中字段的顺序对应;
(3)部分字段插入:值的顺序与给出的列顺序对应;
(4)枚举中的内容可以用数字代替从1开始
MySQL数据库1---数据库简介与基本使用                    原创

insert into students values(0, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(default, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(null, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(0, "xiaoming", 18, 1, 1, "1995-01-01");
insert into students (name, gender) values( "xiaoming", "女");
insert into students (name, gender) values( "xiaoming", "女"),("xiaohong", "男");

2. 修改数据

update students set gender=1;
update students set gender=1 where name="xiaoming";
update students set age=2, gender=1 where id=3;

3. 查询数据
(1)查询所有列

select * from students;
select * from students where id>3;

(2)查询指定列

select name,gender from students;

可以使用as为列或者表指定别名

select name as 姓名,gender as 性别 from students;

还可改变字段的顺序

select id  as 序号,gender as 性别,name as 姓名 from students;

4. 删除数据
(1)物理删除

delete from students;
delete from students where id=3;

(2)逻辑删除(用一个字段来表示是否删除)

alter table students add is_delete bit default 0;

拜师教育学员文章:作者:1191-杨同学, 转载或复制请以 超链接形式 并注明出处 拜师资源博客
原文地址:《MySQL数据库1—数据库简介与基本使用 原创》 发布于2020-09-18

分享到:
赞(0) 打赏

评论 抢沙发

评论前必须登录!

  注册



长按图片转发给朋友

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

Vieu3.3主题
专业打造轻量级个人企业风格博客主题!专注于前端开发,全站响应式布局自适应模板。

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

Q Q 登 录
微 博 登 录