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

本文介绍了MySQL数据库的基础知识,包括数据库的由来、数据存储的演变、数据库的概念及其优势。重点讲解了关系型数据库管理系统RDBMS,以及SQL语言在操作数据库中的作用。此外,还概述了MySQL的特性、安装过程以及数据完整性的重要性,如数据类型和约束。最后,文章详细阐述了如何进行数据表的基本操作和CRUD操作。
摘要由CSDN通过智能技术生成

MySQL数据库

数据库简介

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

数据库就是一种特殊的文件,其中存储着需要的数据(需要特数软件进行操作)。
在这里插入图片描述
关系型数据库核心元素(表之间存在关系):

  1. 数据库中,每行称为一个记录
  2. 每列称为一个字段(能够唯一标记记录的字段称为主键,如id);
  3. 数据表是数据行的集合,数据库是数据表的集合。
    类比Excel,每个数据库中可以有多个数据表:
    在这里插入图片描述
RDBMS
  1. 全称:Relational Database Management System(关系型数据库管理系统)
  2. 当前主要使用两种类型的数据库:关系型数据库和非关系型数据库。所谓的关系型数据库RDBMS,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
  3. 关系型数据库的主要产品:oracle、mysql、ms sql server、sqlite
  4. RDBMS和数据库的关系:
    在这里插入图片描述
    C/S架构
SQL

SQL是结构化查询语言(Structured Query Language),是一种来操作RDBMS的数据库语言,当前的关系型数据库都支持使用SQL语言进行操作,SQL语言不区分大小写。
在这里插入图片描述

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
    在这里插入图片描述
    约束
    在这里插入图片描述

在这里插入图片描述

数据库操作

  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开始
在这里插入图片描述

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;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值