数据库系统原理之SQL(三)
数据库系统原理之SQL(三)
1. SQL的组成
1. 数据查询
2. 数据定义
3. 数据操作
4. 数据控制
2. 数据定义语言
CREATE创建数据库或数据库对象
创建数据库
~~~
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name [DEFAULT] CHARSET SET utf8 [DEFAULT] COLLATE utf8_general_ci
~~~
创建表
~~~
#创建表并设置主键和索引
CREATE TABLE table_name (id int not null AUTO_INCREMENT,name char(50) not null default "",age int null,PRIMARY KEY(id),INDEX index_age(age));
~~~
查看数据库
~~~
#可以根据正则匹配或者where从句来获取想看到的数据库
SHOW {DATABASES | SCHEMAS} [LIKE’pattern’ | WHERE expr]
ALTER对数据库或数据库对象进行修改
修改数据库
ALTER DATABASE db_name DEFAULT CHARACTER SET gb2312 DEFAULT COLLATE gb2312_chinese_ci;
更新表
在表中添加一个字段,并在原表的sex字段之后
ALTER TABLE table_name
ADD COLUMN city char(50) not null default "" after sex;
修改表中的列名或数据类型
修改表table_name中的字段c_name为name,并设置字段类型
ALTER TABLE table_name
CHANGE COLUMN c_name name char(50) not null default "";
~~~修改或删除指定列的默认值
ALTER TABLE table_name
ALTER COLUMN [drop default | set default "" ]
只修改指定列的数据类型,不会干涉它的列名
#first 将此列设为表的第一列
ALTER TABLE table_name
MODIFY COLUMN name char(25) not null first;
删除表中多余的字段
ALTER TABLE table_name
DROP COLUMN name;
为表重新命名
ALTER TABLE table_name
RENAME TO back_table_name;
RENAME TABLE table_name TO back_name;
DROP删除数据库或数据库对象
删除数据库
DROP{DATABASE|SCHEMA}[IF EXISTS]db_name
删除表
DROP TABLE [IF EXISTS] table_name [,table_name2]
查看表
SHOW [FULL] COLUMNS {FROM | IN} tbl_name[{FROM | IN} db_name]
[LIKE’pattern’ | WHERE expr]
{DESCRIBE | DESC} tbl_name [col_name | wild]
3. 数据操纵语言
- SELECT从表中或视图中检索数据(查)
- INSERT将数据插入插入到表或视图中(增)
- UPDATE修改表或视图中的数据(改)
- DELETE删除表或视图中的数据(删)
4. 数据控制语言
- GRANT授予权限
- REVOKE收回权限
5. 索引定义
索引是提高数据文件访问效率的有效方法
- 弊端:
- 索引是以文件的形式存储的,如果有大量的索引,索引文件可能比数据文件更快达到最大的文件尺寸;
- 索引在提高查询速度的同时,会降低更新表的速度。
索引类型
- 普通索引(INDEX或KEY)
- 唯一性索引(UNIQUE)
- 主键(PRIMARY KEY)
创建索引(CREATE INDEX不能创建主键索引)
#在table_name表上的column字段上创建唯一索引index_name,可设置长度和升序降序
CREATE [UNIQUE] INDEX index_name ON table_name (column [(length)][ASC | DESC])
#为表table_name添加索引index_name
ALTER TABLE table_name ADD INDEX index_name(name);
查看索引
SHOW {INDEX | INDEXES | KEYS} {FROM | IN} table_name [{FROM | IN} db_name] [WHERE expr]
删除索引
DROP INDEX index_name ON table_name
ALTER TABLE table_name DROP PRIMARY KEY,DROP INDEX index_name;
6. MySQL内置函数
| 函数 | 描述 | 示例 |
|---|---|---|
| CURDATE() | 返回当前日期 | SELECT CURDATE()---- 2018-09-19 |
| ABS(X) | 返回X的绝对值 | select ABS(-5) ---返回5 |
| AVG(expression) | 返回表达式的平均值 | 返回一个班年龄的平均值---SELECT AVG(age) from class |
| COUNT(expression) | 返回记录数量 | 返回A表中的数据量---SELECT COUNT(*) from A |
| MAX(expression) | 返回字段中的最大值 | 返回一个班中最大的年龄---SELECT MAX(age) from class |
| MIN(expression) | 返回字段中的最小值 | 返回一个班中最小的年龄---SELECT MIN(age) from class |
| SUM(expression) | 返回指定字段的总和 | 返回一个班的分数总和---SELECT SUM(fraction) from class |
数据库系统原理之SQL(三)的更多相关文章
- 数据库系统原理之SQL(四)
数据库系统原理之SQL(四) 1. 数据更新 插入数据 INSERT-VALUES语句 #插入多条数据 insert [into] table_name (column_name,...) value ...
- Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx
Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx 1.1. 数据库的类型,网状,层次,树形数据库,kv数据库.oodb2 1.2. Er模型2 1.3. Sql2 ...
- php面试专题---Mysql索引原理及SQL优化
php面试专题---Mysql索引原理及SQL优化 一.总结 一句话总结: 注意:只写精品 1.为表设置索引要付出代价 是什么? 存储空间:一是增加了数据库的存储空间 修改插入变动索引时间:二是在插入 ...
- 数据库系统原理——ER模型与关系模型
原文链接: http://blog.csdn.net/haovip123/article/details/21614887 犹记得第一次看<数据库系统原理>时看天书的感觉,云里雾里:现在已 ...
- 基于Spark1.3.0的Spark sql三个核心部分
基于Spark1.3.0的Spark sql三个核心部分: 1.可以架子啊各种结构化数据源(JSON,Hive,and Parquet) 2.可以让你通过SQL,saprk内部程序或者外部攻击,通过标 ...
- Linq to Sql : 三种事务处理方式
原文:Linq to Sql : 三种事务处理方式 Linq to SQL支持三种事务处理模型:显式本地事务.显式可分发事务.隐式事务.(from MSDN: 事务 (LINQ to SQL)).M ...
- JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)
Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DD ...
- WebSocket原理与实践(三)--解析数据帧
WebSocket原理与实践(三)--解析数据帧 1-1 理解数据帧的含义: 在WebSocket协议中,数据是通过帧序列来传输的.为了数据安全原因,客户端必须掩码(mask)它发送到服务器的所有 ...
- 7.27实习培训日志-Oracle SQL(三)
Oracle SQL(三) 视图 特性 简单视图 复杂视图 关联的表数量 1个 1个或多个 查询中包含函数 否 是 查询中包含分组数据 否 是 允许对视图进行DML操作 是 否 CREATE [OR ...
随机推荐
- 一文带你了解git
git简介 什么是git? git是当今世界上最先进的分布式的版本控制系统. 版本控制系统分集中式的和分布式的,集中式的主要代表有CVS.SVN,而Git是分布式版本控制系统的佼佼者. 那什么是集中式 ...
- ListView在ScrollView中不显示全部的问题
在实际应用中,我们可能会遇到把ListView放到ScrollView中的情况,在这种情况下,ListView的滑动属性与ScrollView的滑动出现冲突,从而ListView只显示一项.这里提供一 ...
- 编码原理_base64编码原理
1.1 Base64编码原理 1.1.1 概要: Base64是通讯传输中较为常见的编码方式之一. (注意是编码算法,而非加密算法) 参数传输的过程中会经常遇到的一种情况:使用英文不会涉及到乱码, ...
- 个人永久性免费-Excel催化剂功能第18波-在Excel上也能玩上词云图
这年头数据可视化日新月异,在Excel上做数据分析,最后一步,难免要搞个图表输出高大上一回,微软也深知此道,在Excel2016上更新了一大波图表功能,市场上很耀眼的词云图还是没加进来,虽然在各大的在 ...
- Android 常用 Manager的总结
Android 常用 Manager的总结 1 smsManager 发送短信 --使用方法 --SmsManager smsManager = SmsManager.getDe ...
- web页面保存图片到本地
web页生成分享海报功能踩坑经验 https://blog.csdn.net/candy_home/article/details/78424642 https://www.jianshu.com/p ...
- 深入理解Java中的锁(一)
Java中锁的概念 自旋锁 : 是指当一个线程在获取锁的时候,如果锁已经被其他线程获取,那么该线程将循环等待,然后不断判断锁是否能够被成功获取,直到获取到锁才会退出循环. 乐观锁 : 假定没有冲突,在 ...
- .Net微信网页开发之使用微信JS-SDK调用微信扫一扫功能
前言: 之前有个项目需要调用微信扫描二维码的功能,通过调用微信扫码二维码功能,然后去获取到系统中生成的二维码信息.正好微信JS-SDK提供了调用微信扫一扫的功能接口,下面让我们来看看是如何实现的吧. ...
- activiti工作流委托功能的设计和实现
最近公司开发一个项目,客户提出了一个需求,用户在出差的时候,可以将自己的工作进行委托.可以指定委托时间.委托工作内容.指定委托人等等内容. 然后我就上网查询资料,发现activiti工作流本身并不支持 ...
- 【Demo 1】基于object_detection API的行人检测 1:环境与依赖
环境 系统环境: win10.python3.6.tensorflow1.14.0.OpenCV3.8 IDE: Pycharm 2019.1.3.JupyterNotebook 依赖 安装objec ...