MySQL SQL语法详解:数据库与数据表操作
需积分: 9 144 浏览量
更新于2024-08-15
收藏 18.68MB PPT 举报
本文主要介绍了在MySQL中获取数据库和数据表信息的相关SQL语法,包括了数据库的选取、创建、丢弃和变更,以及数据表和索引的操作。此外,还涉及了从数据表中检索信息、事务处理和管理性语句的使用。
1. 数据库操作:
- `USE` 语句用于选择要使用的数据库。
- `CREATE DATABASE` 用于创建新的数据库。
- `DROP DATABASE` 用于删除已存在的数据库。
- `ALTER DATABASE` 用于更改现有数据库的属性,如字符集或排序规则。
2. 数据表和索引操作:
- `CREATE TABLE` 用于创建数据表,定义列名、数据类型和其他约束。
- `DROP TABLE` 用于删除数据表。
- `CREATE INDEX` 创建索引,以提高查询性能。
- `DROP INDEX` 删除已经创建的索引。
- `ALTER TABLE` 用于修改已有数据表的结构,如添加、删除或更改列,或者更改表的名称。
3. 获取信息:
- `DESCRIBE` 语句用于显示数据表的结构,包括列名、数据类型和是否允许为空等信息。
- `SHOW` 命令可以用来显示数据库信息,如数据表列表、用户权限等。
4. 从数据表中检索信息:
- `SELECT` 语句是最基本的查询工具,用于从数据表中检索指定的列或所有列。
- `UNION` 操作符用于合并两个或更多`SELECT`语句的结果集。
5. 事务处理:
- `BEGIN` 开始一个事务。
- `COMMIT` 提交事务,保存所有更改。
- `ROLLBACK` 回滚事务,撤销所有更改。
- `SET AUTO.COMMIT` 用于设置自动提交模式,如果设为1,则每次执行SQL语句后都会自动提交。
6. 数据操作:
- `INSERT` 用于向数据表中插入新记录。
- `DELETE` 用于从数据表中删除记录。
- `LOAD DATA` 用于快速导入大量数据到数据表。
- `REPLACE` 与`INSERT`类似,但如果有重复键值,会先删除旧记录再插入新记录。
- `UPDATE` 用于更新数据表中的记录。
7. 管理性语句:
- `FLUSH` 用于刷新缓存、日志等,确保系统状态同步。
- `GRANT` 和 `REVOKE` 分别用于授予和撤销用户的权限。
例子中给出了三个数据表:`student`(学生信息)、`score`(成绩)和`event`(事件),以及一个`absence`(缺席记录)的数据表。这些表格包含了学生的姓名、性别、ID,事件的日期、类型,以及成绩和缺席情况等信息,展示了实际数据库应用中的数据组织形式。
2018-04-09 上传
2022-09-21 上传
2021-10-02 上传
2023-07-15 上传
2023-05-30 上传
2023-08-22 上传
2023-05-26 上传
2023-07-12 上传
2023-05-24 上传
昨夜星辰若似我
- 粉丝: 48
- 资源: 2万+
最新资源
- 基于Python和Opencv的车牌识别系统实现
- 我的代码小部件库:统计、MySQL操作与树结构功能
- React初学者入门指南:快速构建并部署你的第一个应用
- Oddish:夜潜CSGO皮肤,智能爬虫技术解析
- 利用REST HaProxy实现haproxy.cfg配置的HTTP接口化
- LeetCode用例构造实践:CMake和GoogleTest的应用
- 快速搭建vulhub靶场:简化docker-compose与vulhub-master下载
- 天秤座术语表:glossariolibras项目安装与使用指南
- 从Vercel到Firebase的全栈Amazon克隆项目指南
- ANU PK大楼Studio 1的3D声效和Ambisonic技术体验
- C#实现的鼠标事件功能演示
- 掌握DP-10:LeetCode超级掉蛋与爆破气球
- C与SDL开发的游戏如何编译至WebAssembly平台
- CastorDOC开源应用程序:文档管理功能与Alfresco集成
- LeetCode用例构造与计算机科学基础:数据结构与设计模式
- 通过travis-nightly-builder实现自动化API与Rake任务构建