Mysql1_概述和SQL

Mysql概述

1.为什么学习MySQL数据库?

在这里插入图片描述
MySQL广占IT市场,比如淘宝网易百度新浪facebook等大部分互联网公司,都在使用mysql软件,而且在网络游戏领域,大部分的后台数据库都在使用mysql,如劲舞团、魔兽世界,还有更厉害的,中国电网中国移动中很多项目也在使用我们的mysql。

2.数据库概述

1.什么是数据库

数据库是持久化数据的一种介质,可以理解成用来存储和管理数据的仓库!
持久化(persistence):把数据保存到可掉电式存储设备中以供之后使用。持久化的大多数时候是将内存中的数据存储在数据库中,当然也可以存储在磁盘文件、XML数据文件中。

2.为什么要用数据库

保存数据 的容器:数组、集合、文件

保存到文件:
在这里插入图片描述

  • 可将数据持久化到硬盘。
  • 可存储大量数据。
  • 方便检索。
  • 保证数据的一致性、完整性。
  • 安全,可共享。
  • 通过组合分析,可以产生新数据。

3.常见数据库产品

Oracle:甲骨文
DB2:IBM
SQL Server:微软
MySQL:甲骨文

4.数据库相关概念

DB
数据库( database ):存储数据的“仓库”。它保存了一系列有组织的数据。
DBMS
数据库管理系统( Database Management System )。数据库是通过 DBMS 创建和操作的容器。
SQL
结构化查询语言( Structure Query Language ):专门用来与数据库通信的语言。

三者的关系:
在这里插入图片描述

5.数据库存储数据的特点

  • 将数据放到表中,表再放到库中 。
  • 一个数据库中可以有多个表,每个表都有一个的名字,用来标识自己。表名具有唯一性。
  • 表具有一些特性,这些特性定义了数据在表中如何存储,类似java中 “类”的设计。
  • 表由列组成,我们也称为字段。所有表都是由一个或多个列组成的,每一列类似java 中的”属性”。
  • 表中的数据是按行存储的,每一行类似于java中的“对象”。

表——类
列,字段——属性
行——对象

2. MySQL数据库的介绍

1.MySQL产品的介绍

MySQL是一种开放源代码的关系型数据库管理系统,开发者为瑞典MySQL AB公司。在2008年1月16号被Sun公司收购。而2009年,SUN又被Oracle收购.目前 MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库(Facebook, Twitter, YouTube)。阿里提出“去IOE”,更多网站也开始选择MySQL。(其本意是,在阿里巴巴的IT架构中,去掉IBM的小型机、Oracle数据库、EMC存储设备,代之以自己在开源软件基础上开发的系统。传统上,一个高端大气的数据中心,IBM小型机、Oracle数据库、EMC存储设备,可以说缺一不可。)

2.MySQL产品的优点

成本低:开放源代码,一般可以免费试用。
性能高:执行很快。
简单:很容易安装和使用。

SQL

1.SQL概述

1.什么是SQL

SQL(Structured Query Language)是“结构化查询语言”,它是对关系型数据库的操作语言。它可以应用到所有关系型数据库中,例如:MySQL、Oracle、SQL Server等。SQL标准有:

  • 1986年,ANSI X3.135-1986,ISO/IEC 9075:1986,SQL-86。
  • 1989年,ANSI X3.135-1989,ISO/IEC 9075:1989,SQL-89。
  • 1992年,ANSI X3.135-1992,ISO/IEC 9075:1992,SQL-92(SQL2)。
  • 1999年,ISO/IEC 9075:1999,SQL:1999(SQL3)。
  • 2003年,ISO/IEC 9075:2003,SQL:2003。
  • 2008年,ISO/IEC 9075:2008,SQL:2008。
  • 2011年,ISO/IEC 9075:2011,SQL:2011。
  • 2016年,ISO/IEC 9075:2016,SQL:2016。

这些标准就与JDK的版本一样,在新的版本中总要有一些语法的变化。不同时期的数据库对不同标准做了实现。
虽然SQL可以用在所有关系型数据库中,但很多数据库还都有标准之后的一些语法,我们可以称之为“方言”。例如MySQL中的LIMIT语句就是MySQL独有的方言,其它数据库都不支持!当然,Oracle或SQL Server都有自己的方言。

2.SQL语法要求

  • SQL语句可以单行或多行书写,以分号结尾;
  • 可以用空格和缩进来来增强语句的可读性;
  • 关键字不区别大小写,建议使用大写;

2.分类

SQL的分类其实只有三种,如果把DML中的查询操作单独分出来就是DQL,三种和四种的说法都是正确的。

  • DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
  • DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
  • DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
  • DQL(Data Query Language):数据查询语言,用来查询记录(数据)。

1.DML

DML用于查询与修改数据记录,包括如下SQL语句:

  • INSERT:添加数据到数据库中
  • UPDATE:修改数据库中的数据
  • DELETE:删除数据库中的数据
  • SELECT:选择(查询)数据
    • SELECT是SQL语言的基础,最为重要。

2.DDL

DDL用于定义数据库的结构,比如创建、修改或删除数据库对象,包括如下SQL语句:
CREATE TABLE:创建数据库表
ALTER TABLE:更改表结构、添加、删除、修改列长度
DROP TABLE:删除表
CREATE INDEX:在表上建立索引
DROP INDEX:删除索引

3.DCL

DCL用来控制数据库的访问,包括如下SQL语句:

  • GRANT:授予访问权限
  • REVOKE:撤销访问权限
  • COMMIT:提交事务处理
  • ROLLBACK:事务处理回退
  • SAVEPOINT:设置保存点
  • LOCK:对数据库的特定部分进行锁定
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值