SQL学习Day1-初识数据库与SQL

SQL学习Day1-初识数据库与SQL

内容参照天池训练营(如侵权,请联系我,会删除)

https://tianchi.aliyun.com/forum/postDetail?spm=5176.20222307.J_9059755190.2.53414cb331KXck&postId=163421

 

一、初识数据库

数据库是将大量数据保存起来,通过计算机加工而成的可以 进行高效访问的数据集合。该数据集合称为数据库(Database,DB)。用来管理数据库的计算机系统称为数据库管理系统(Database Management System,DBMS)。

1.1 DBMS的种类

DBMS 主要通过数据的保存格式(数据库的种类)来进行分类,现阶段主要有以下 5 种类型.

  • 层次数据库(Hierarchical Database,HDB)
  • 关系数据库(Relational Database,RDB)

这种类型的 DBMS 称为关系数据库管理系统(Relational Database Management System,RDBMS)。比较具有代表性的 RDBMS 有如下 5 种。

* Oracle Database:甲骨文公司的RDBMS
* SQL Server:微软公司的RDBMS
* DB2:IBM公司的RDBMS
* PostgreSQL:开源的RDBMS
* MySQL:开源的RDBMS
  • 面向对象数据库(Object Oriented Database,OODB)
  • XML数据库(XML Database,XMLDB)
  • 键值存储系统(Key-Value Store,KVS),举例:MongoDB

 

1.2 RDBMS的常见系统结构

使用 RDBMS 时,最常见的系统结构就是客户端 / 服务器类型(C/S类型)这种结构(图 1-3)

 

1.3 数据库安装

推荐使用docker安装mysql。快速简洁

 

二、初识 SQL

2.1 概念介绍

数据库中存储的表结构类似于excel中的行和列,在数据库中,行称为记录,它相当于一条记录,列称为字段,它代表了表中存储的数据项目。

行和列交汇的地方称为单元格,一个单元格中只能输入一条记录。

SQL是为操作数据库而开发的语言。国际标准化组织(ISO)为 SQL 制定了相应的标准,以此为基准的SQL 称为标准 SQL(相关信息请参考专栏——标准 SQL 和特定的 SQL)。

完全基于标准 SQL 的 RDBMS 很少,通常需要根据不同的 RDBMS 来编写特定的 SQL 语句,原则上,本课程介绍的是标准 SQL 的书写方式。

根据对 RDBMS 赋予的指令种类的不同,SQL 语句可以分为以下三类:

  • DDL(Data Definition Language,数据定义语言) 用来创建或者删除存储数据用的数据库以及数据库中的表等对象。DDL 包含以下几种指令。
    • CREATE : 创建数据库和表等对象

    • DROP : 删除数据库和表等对象

    • ALTER : 修改数据库和表等对象的结构

  • DML(Data Manipulation Language,数据操纵语言) 用来查询或者变更表中的记录。DML 包含以下几种指令。

    • SELECT :查询表中的数据

    • INSERT :向表中插入新数据

    • UPDATE :更新表中的数据

    • DELETE :删除表中的数据

  • DCL(Data Control Language,数据控制语言) 用来确认或者取消对数据库中的数据进行的变更。除此之外,还可以对 RDBMS 的用户是否有权限操作数据库中的对象(数据库表等)进行设定。DCL 包含以下几种指令。

    • COMMIT : 确认对数据库中的数据进行的变更

    • ROLLBACK : 取消对数据库中的数据进行的变更

    • GRANT : 赋予用户操作权限

    • REVOKE : 取消用户的操作权限

 

三、实战(练习)

-- 建表
create table addressbook(
    regist_no   INTEGER NOT NULL,
    name VARCHAR(128)   NOT NULL,
    address VARCHAR(256)    NOT NULL,
    tel_no  CHAR(10),
    mail_address    CHAR(20),
    PRIMARY KEY (regist_no)
);
 
-- 追加字段
alter table addressbook add column postal_code char(8) not null;
 
-- 删除表结构和数据
drop table addressbook;

-- 删除数据,保留表结构
-- truncate table addressbook;
 
-- 重建数据表
create table if not exists addressbook(
    regist_no   INTEGER NOT NULL,
    name VARCHAR(128)   NOT NULL,
    address VARCHAR(256)    NOT NULL,
    tel_no  CHAR(10),
    mail_address    CHAR(20),
    postal_code char(8) not null,
    PRIMARY KEY (regist_no)
);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值