博客
关于我
MySql-2019-4-21-复习
阅读量:797 次
发布时间:2023-02-11

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

MySQL数据库基础入门

数据库基础

数据库是存储和管理数据的容器,主要包括表、视图、存储过程、函数、触发器、索引等数据库对象。数据库可以分为两大类:

系统数据库

系统数据库由数据库管理系统自带,通常不可修改,主要包括:

  • information_schema:存储数据库对象的信息,如用户表、列信息、权限、字符集、分区等。
  • performance_schema:记录数据库服务器性能参数信息。
  • mysql:存储数据库用户权限信息。
  • test:可供任何用户使用的测试数据库。

用户数据库

用户数据库是由用户自定义创建的数据库,通常一个项目使用一个用户数据库。数据库名可以使用CREATE DATABASE命令创建,删除使用DROP DATABASE命令。

数据库操作

查看和切换数据库

使用SHOW DATABASES命令查看所有数据库,USE database_name命令切换到指定数据库。

查看数据库表

SHOW TABLES命令可以列出指定数据库中的所有表。

创建和删除数据库

CREATE DATABASE database_name创建数据库,DROP DATABASE database_name删除数据库。

存储引擎

MySQL支持多种存储引擎,主要有MyISAMInnoDB两种。MyISAM适合需要高插入、查询速度但不需要事务支持的场景,而InnoDB支持事务和外键,适合需要数据一致性和复杂约束的应用。

数据类型

MySQL提供丰富的数据类型,主要包括:

  • 整数类型INTBIGINT
  • 浮点数和小数FLOATDOUBLEDECIMAL
  • 字符类型CHARVARCHARTEXT
  • 日期和时间DATETIMESTAMPTIMEYEAR
  • 二进制类型BINARYVARBINARYBLOB
  • 布尔类型BIT

DECIMAL类型推荐用于存储高精度的金额或货币数据。

表操作

表的创建

CREATE TABLE命令用于创建表,格式如下:

CREATE TABLE 表名(    列名1 列类型 [约束],    列名2 列类型 [约束],    ...);

在表名中使用关键字时需加反引号,建议使用t_作为表名前缀。

查看表结构

使用DESC命令查看表结构,SHOW CREATE TABLE命令查看表的创建语句。

删除表

使用DROP TABLE命令删除表。

表约束

表约束可以对单个列进行限制,常见约束包括:

  • 非空约束NOT NULL
  • 默认值约束DEFAULT
  • 唯一约束UNIQUE
  • 主键约束PRIMARY KEY
  • 主键自增AUTO_INCREMENT
  • 外键约束FOREIGN KEY

查询操作

简单查询

SELECT语句用于从表中检取数据,语法如下:

SELECT [列名列表] [DISTINCT] FROM 表名;

DISTINCT关键字用于去重。

过滤查询

使用WHERE子句对结果进行过滤,语法如下:

SELECT [列名列表] FROM 表名 WHERE 条件;

支持多种比较运算符和逻辑运算符。

范围查询

BETWEENIN用于限制查询范围,IS NULL用于查找空值,LIKE用于文本匹配。

排序查询

ORDER BY子句用于对结果进行排序,语法如下:

SELECT [列名列表] FROM 表名 ORDER BY 列名 [ASC/DESC];

分页查询

MySQL支持逻辑分页和物理分页,推荐使用物理分页:

SELECT * FROM 表名 LIMIT 开始位置, 每页大小;

多表查询

内连接查询

内连接用于将两个或多个表的数据结合,常用JOIN关键字:

SELECT * FROM 表名A JOIN 表名B ON 表名A.列 = 表名B.列;

隐式内连接和显式内连接效果相同。

外连接查询

外连接用于关联不相关的表,结果可能包含NULL值。

外键约束

外键约束用于维护数据库的数据一致性,主要包括:

  • 外键列名称
  • 外引用的主键表和主键列
  • 外键的更新和删除行为选择

在使用外键时,需确保目标表的引擎支持外键(如InnoDB)。

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

你可能感兴趣的文章
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>