MySQL基础笔记(一) SQL简介+数据类型
MySQL是一个关系型数据库管理系统(RDBMS),它是当前最流行的 RDBMS 之一。MySQL分为社区版和企业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
一、什么是SQL
SQL,即结构化查询语言(Structured Query Language),是与关系型数据库进行通信的标准语言。目前最新的标准是2008年7月开始采用的SQL-2008。
所谓SQL实现是指特定厂商的SQL产品或关系型数据库管理系统(RDBMS),目前主流的关系型数据库有DB2、Oracle、SQL Server、MySQL、PostgresSQL等。各种不同的SQL实现对SQL语言的支持与标准存在着细微的不同,所以,实际上不同数据库系统之间的SQL不能完全相互通用。
二、 SQL命令类型
结构化查询语言包含6个部分。
2.1 数据定义语言(DDL)
数据定义语言(DDL)用于创建和重构数据库对象,比如创建和删除表。
create table
alter table
drop table
create index
alter index
drop index
create view
drop view
2.2 数据操作语言(DML)
数据操作语言(DML)用于操作关系型数据库对象内部的数据。
insert
update
delete
2.3 数据查询语言(DQL)
数据查询语言(DQL)是最受关注的部分。虽然只有一个命令,但这个命令具有很多选项和子句。
select
2.4 数据控制语言(DCL)
数据控制语言(DCL)用于控制对数据库里数据的访问,比如创建与用户访问相关的对象、控制用户的权限。
alter password
grant /*赋予访问权限*/
revoke /*取消访问权限*/
2.5 数据管理命令
数据管理命令用于对数据库里的操作进行审计和分析,还有助于分析系统性能。
start audit /*审计*/
stop audit
2.6 事务控制命令
事务控制命令用于管理数据库事务,确保被DML语句影响的表的所有行及时得以更新。
commit /*保存数据库事务*/
rollback /*撤销数据库事务*/
savepoint /*在一组事务里创建标记点,用于回退(rollback)*/
set transaction /*设置事务的名称*/
三、数据类型
MySQL支持多种数据类型,主要有数值类型、日期/时间类型、字符串类型。
3.1 数值类型
数值类型主要用来存储数字,包括整数类型和浮点数类型。
3.1.1 整数类型
| 类型名称 | 说明 | 存储需求 |
|---|---|---|
| TINYINT | 很小的整数 | 1个字节 |
| SMALLINT | 小的整数 | 2个字节 |
| MEDIUMINT | 中等大小的整数 | 3个字节 |
| INT(INTEGER) | 普通大小的整数 | 4个字节 |
| BIGINT | 大整数 | 8个字节 |
3.1.2 浮点数类型
| 类型名称 | 说明 | 存储需求 |
|---|---|---|
| FLOAT | 单精度浮点数 | 4个字节 |
| DOUBLE | 双精度浮点数 | 8个字节 |
| DECIMAL(m,d) | 压缩的“严格”定点数 | m+2个字节 |
DECIMAL(m,d)中,m表示有效位,d表示保留小数位数。
3.2 日期与时间类型
MySQL中有多种表示日期与时间的类型,如下表:
| 类型名称 | 日期格式 | 范围 | 存储需求 |
|---|---|---|---|
| YEAR | YYYY | 1901 ~ 2155 | 1字节 |
| TIME | HH:MM:SS | -838:59:59 ~ 838:59:59 | 3字节 |
| DATE | YYYY-MM-DD | 1000-01-01 ~ 9999-12-31 | 3字节 |
| DATETIME | YYYY-MM-DD HH:MM:SS | 1000-01-01 00:00:00 ~ 9999-12-31 23:59:59 | 8字节 |
| TIMESTAMP | YYYY-MM-DD HH:MM:SS | 1970-01-01 00:00:01 UTC ~ 2038-01-19 03:14:07 UTC | 4字节 |
TIMESTAMP 显示宽度固定在19个字符,显示格式与 DATETIME 的相同。但是存储字节和支持范围不同,另外还有一个最大的不同是:
- DATETIME 按实际的输入格式存储,输入什么就存储什么,与时区无关;而 TIMESTAMP 以 UTC(世界标准时间)格式保存,存储时对当前时区进行转换,检索时再转换回当前时区。即查询时,根据当前时区的不同,显示的时间值是不同的。
3.3 字符串类型
MySQL支持两种字符串类型:文本字符串、二进制字符串
3.3.1 文本字符串类型
| 类型名称 | 说明 | 存储需求 |
|---|---|---|
| CHAR(m) | 固定长度字符串 | m字节,1<=m<=255 |
| VARCHAR(m) | 变长字符串 | p+1字节,p<=m和1<=m<=255 |
| TINYTEXT | 非常小的字符串 | p+1字节,p<28 |
| TEXT | 小的字符串 | p+2字节,p<216 |
| MEDIUMTEXT | 中等大小的字符串 | p+3字节,p<224 |
| LONGTEXT | 大的字符串 | p+4字节,p<232 |
| ENUM | 枚举类型 | 1或2个字节,取决于枚举值的数目(最多65535) |
| SET | 集合类型 | 1,2,3,4或8个字节,取决于集合成员数量 |
类型 ENUM 与 SET 的相同之处是它们在内部都用整数表示,定义列表中每个成员都有一个索引编号。而它们的不同之处在于:
- ENUM最多可以有65535个枚举值,而SET最多有64个成员。
- ENUM类型的字段每次取值只能取一个,而SET类型字段可以取零个或多个成员的组合形式。
3.3.2 二进制字符串类型
| 类型名称 | 说明 | 存储需求 |
|---|---|---|
| BIT(m) | 位字段类型 | 大约(m+7)/8个字节 |
| BINARY(m) | 固定长度二进制字符串 | m个字节 |
| VARBINARY(m) | 变长二进制字符串 | m+1个字节 |
| TINYBLOB(m) | 非常小的BLOB | p+1字节,p<28 |
| BLOB(m) | 小BLOB | p+2字节,p<216 |
| MEDIUMBLOB(m) | 中等大小的BLOB | p+3字节,p<224 |
| LONGBLOB(m) | 非常大的BLOB | p+4字节,p<232 |
BLOB类型是一个二进制大对象,通常用来存储可变的大容量数据,比如图片、音频或视频。
为了优化存储,在任何情况下均应使用最精确的类型。例如,如果列的值的范围为从1到99999,若使用整数,则MEDIUMINT UNSIGNED是好的类型。在所有可以表示该列值的类型中,该类型使用的存储最少。
MySQL基础笔记(一) SQL简介+数据类型的更多相关文章
- MYSQL基础笔记(六)- 数据类型一
数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...
- MYSQL基础笔记(七)- 数据类型二
字符串类型 在SQL中,讲字符串类型分成了六类:char,varchar,text,blob,enum,set char,定长字符串 磁盘(二维表)在定义结构的时候,就已经确定了最终数据的存储长度. ...
- MYSQL基础笔记(五)- 练习作业:站点统计练习
作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...
- MYSQL基础笔记(二)-SQL基本操作
SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...
- MYSQL基础笔记(三)-表操作基础
数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...
- MYSQL基础笔记(一)
关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...
- Mysql学习笔记(二)数据类型 补充
原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...
- Mysql学习笔记(一)数据类型
原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型 Mysql数据类型 含义(有符号) tinyint(m ...
- MYSQL基础笔记(四)-数据基本操作
数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...
- MySql基础架构以及SQL语句执行流程
01. mysql基础架构 SQL语句是如何执行的 学习一下mysql的基础架构,从一条sql语句是如何执行的来学习. 一般我们写一条查询语句类似下面这样: select user,password ...
随机推荐
- Warning: date(): It is not safe to rely on the system's timezone settings. You are *required* to use ...报错
错误截图 Warning: date(): It is not safe to rely on the system's timezone settings. You are *required* t ...
- check.pl
比对两个文件并纠错 #!/usr/bin/perl use strict; use warnings; ###############################################m ...
- jQuery闪烁提示,让新消息在网页标题显示
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head& ...
- uwsgs loading shared libraries: libicui18n.so.58 异常处理
背景 想使用 ningx + uwsgi + flask 搭建 python 应用环境 Python使用的是anaconda3(pyhton 3.6) 依赖包安装完毕,但是执行 uwsgi 的时候出现 ...
- Nginx安装及基本配置
本文内容: 90%来自以下网址:http://www.nginx.cn/install ,修改了一些版本信息 10%来自以下网址:http://nginx.org/en/docs/beginners_ ...
- hihocoder 1584 Bounce (数学 && 规律) ACM-ICPC北京赛区2017网络赛
题意: 给定一副n*m的格子图, 问从左上角的点开始往右下角滑,碰到墙壁就反弹, 碰到角落就停止, 问恰好经过一次的格子有多少个. 如图,恰好经过一次的格子有39个. 分析: 首先要引入两个概念, “ ...
- [第一波模拟\day3\T3]{益智游戏}(game.cpp)
[问题描述] 小P和小R在玩一款益智游戏.游戏在一个正权有向图上进行. 小P控制的角色要从A点走最短路到B点,小R控制的角色要从C点走最短路到D点. 一个玩家每回合可以有两种选择,移动到一个相邻节点或 ...
- 一个监控oracle数据库某个字段值变化并发送邮件报警的脚本
talk is cheap,here is the code: #!/bin/sh export ORACLE_HOME=/u01/app/oracle/product//client_1/ expo ...
- Leetcode 224.基本计算器
基本计算器 实现一个基本的计算器来计算一个简单的字符串表达式的值. 字符串表达式可以包含左括号 ( ,右括号 ),加号 + ,减号 -,非负整数和空格 . 示例 1: 输入: "1 + 1 ...
- 准确率(Precision),召回率(Recall)以及综合评价指标(F1-Measure)
准确率和召回率是数据挖掘中预测,互联网中得搜索引擎等经常涉及的两个概念和指标. 准确率:又称“精度”,“正确率” 召回率:又称“查全率” 以检索为例,可以把搜索情况用下图表示: 相关 不相关 检索 ...