博客
关于我
MySQL快速入门
阅读量:398 次
发布时间:2019-03-05

本文共 2634 字,大约阅读时间需要 8 分钟。

MySQL是一款流行的关系型数据库,支持结构化查询语言SQL(Structured Query Language)。尽管不同数据库系统的行为有细微差异,但MySQL作为其中一员,在数据库管理和数据处理方面表现优异。本文将从基础到高级功能,全面介绍MySQL的操作方法。

数据库管理

MySQL服务实例下可以维护多个数据库,其中一些数据库用于管理用户和权限信息。数据库管理中,常用的SQL语句包括:

  • SHOW DATABASES;:显示当前实例所拥有的所有数据库。
  • DROP DATABASE [database_name];:删除指定数据库。
  • CREATE DATABASE [IF NOT EXISTS] database_name;:创建新的数据库。
  • USE database_name;:切换到指定数据库。

数据表是数据存储的基本单元,MySQL支持多种数据类型来满足不同需求。例如:

  • INT:32位有符号整数。
  • DOUBLE:双精度浮点数。
  • VARCHAR(limit):变长字符串。
  • DATEDATETIME:日期和日期时间类型。

数据表的创建和修改是数据库管理的重要环节。例如,创建表的基本语法如下:

CREATE TABLE `user` (    `id` INT PRIMARY KEY AUTO_INCREMENT,    `username` VARCHAR(20) DEFAULT "",    `password` CHAR(20) DEFAULT "",    `gender` CHAR(1),    `age` INT);

数据定义语言(DDL)用于操作数据表和其他数据库对象。常见操作包括:

  • 删除表:

    DROP TABLE `user`;
  • 修改表结构:

    ALTER TABLE `user` ADD `age` INT DEFAULT 0;ALTER TABLE `user` MODIFY `gender` INT DEFAULT 0;

数据操作语言(DML)

DML用于操作表中的数据,常见操作包括:

  • 插入数据:

    INSERT INTO `user` (`username`, `password`) VALUES ("abcd", "1234");
  • 更新数据:

    UPDATE `user` SET `username` = "abc" WHERE `id` = 1;
  • 删除数据:

    DELETE FROM `user` WHERE `id` = 1;
  • 查询数据:

    查询用户表中所有记录的所有字段:

    SELECT * FROM `user`;

    查询符合条件的记录:

    SELECT `username` FROM `user` WHERE `gender` = 'M';

    限制返回结果数量:

    SELECT * FROM `user` LIMIT 10 OFFSET 10;

查询优化

在多表查询中,合理使用表别名和排序操作可以提高查询效率。例如:

SELECT u.`username` AS name FROM `user` u WHERE u.`gender` = 'M';

为了避免重复结果,可以使用DISTINCT关键字:

SELECT DISTINCT(`username`) FROM `user`;

聚集操作

MySQL支持多种聚集函数,例如AVGSUMCOUNT等。使用GROUP BY子句可以按多个字段分组聚集数据。例如:

SELECT AVG(`age`) FROM `user` GROUP BY `gender`;

HAVING子句可以用于过滤聚集结果:

SELECT gender, AVG(`age`) FROM `user` WHERE gender = 'M' GROUP BY gender;

排序操作

使用ORDER BY语句可以对查询结果进行排序。例如:

SELECT * FROM `user` ORDER BY age DESC LIMIT 10;

ORDER BY还可以对多列进行排序:

SELECT * FROM `user` ORDER BY age DESC, username ASC;

联合查询

联合查询可以通过JOIN操作将多个表连接起来。例如:

SELECT p.`id` AS post_id, title, content, u.`username` AS author FROM `post` pJOIN `user` u ON p.`uid` = u.`id` WHERE u.`gender` = 'F';

子查询

子查询可以将另一个查询的结果作为数据源。例如:

SELECT COUNT(*) AS comment_count FROM `comment` WHERE post_id IN (SELECT `id` FROM `likes`);

视图

视图可以根据查询结果创建临时表。例如:

CREATE VIEW `post_detail` AS SELECT p.`id` AS post_id, title, content, u.`username` AS author_name FROM `post` pJOIN `user` u ON p.`uid` = u.`id` WHERE u.`gender` = 'F';

约束

约束用于保证数据的完整性。常见约束类型包括:

  • 非空约束:确保字段不允许为空。

    CREATE TABLE `user` (`username` VARCHAR(20) NOT NULL);
  • 唯一约束:确保字段值在表中唯一。

    CREATE TABLE `user` (`username` VARCHAR(20) UNIQUE);
  • 主键约束:确保主键字段唯一且不为空。

    CREATE TABLE `user` (`id` INT PRIMARY KEY AUTO_INCREMENT);
  • 外键约束:将一个表的字段与另一个表的主键关联。

    CREATE TABLE `post` (id INT PRIMARY KEY AUTO_INCREMENT, uid INT, FOREIGN KEY (uid) REFERENCES `user`.`id`);

通过以上操作,可以充分利用MySQL的功能,高效管理和操作数据库。

转载地址:http://waqzz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现使用Prim算法确定图的最小生成树算法(附完整源码)
查看>>
Objective-C实现使用二元运算符将两个数字相加fullAdder算法(附完整源码)
查看>>
Objective-C实现使用分而治之找到单峰列表的峰值算法(附完整源码)
查看>>
Objective-C实现使用数组实现约瑟夫环(附完整源码)
查看>>
Objective-C实现使用矩阵求幂的第 n 个斐波那契算法(附完整源码)
查看>>
Objective-C实现使用管道重定向进程输入输出(附完整源码)
查看>>
Objective-C实现倒计时(附完整源码)
查看>>
Objective-C实现借记款项功能(附完整源码)
查看>>
Objective-C实现全年3天打渔,2天晒网(附完整源码)
查看>>
Objective-C实现八进制转十进制算法(附完整源码)
查看>>
Objective-C实现共享内存(附完整源码)
查看>>
Objective-C实现关机、重启、注销功能的实现(附完整源代码)
查看>>
Objective-C实现关机程序(附完整源码)
查看>>
Objective-C实现关系矩阵A和B的乘积(附完整源码)
查看>>
Objective-C实现关系矩阵乘法(附完整源码)
查看>>
Objective-C实现关系矩阵乘法(附完整源码)
查看>>
Objective-C实现关键字移位字母表密码算法(附完整源码)
查看>>
Objective-C实现内存映射文件(附完整源码)
查看>>
Objective-C实现内存泄露检查(附完整源码)
查看>>
Objective-C实现内核中的自旋锁结构(附完整源码)
查看>>