如果您是一位刚刚开始学习MySQL的新手,本文将为您提供一些实用的入门知识和技巧,帮助您快速上手。
【MySQL新手入门系列一】:手把手教你入门MySQL
前面我们已经大致讲了一下mysql的安装等介绍,本篇文章将以windows为例,介绍MySQL的数据库及数据表的操作(增删改查)。
目录
一、概览
在MySQL安装完成后,接下来,我们就要创建数据库及创建数据表。
二、MySQL数据库操作
MySQL 安装好之后就可以进行数据库的相关操作,这时候,是没有我们自己使用的数据库的,所以我们得先新建一个我们自己的数据库。
2.1 创建数据库
语法:
CREATEDATABASE[IFNOTEXISTS]<数据库名>[[DEFAULT]CHARACTERSET<字符集名>][[DEFAULT]COLLATE<校对规则名>];
语法说明如下:
1、<数据库名>:创建数据库的名称,不能以数字开头
2、IF NOT EXISTS:在创建数据库之前进行判断,当数据库不存在时,才会执行创建语句。
3、[DEFAULT] CHARACTER SET:指定数据库的字符集。目的是为了避免在数据库中存储的数据出现乱码的情况。
4、[DEFAULT] COLLATE:指定字符集的默认校对规则。
我们来举个例子,现在有个书店,要存书书相关的信息,创建一个新的数据库,命名为 “bookstore”:
CREATEDATABASEIFNOTEXISTS bookstore
DEFAULTCHARACTERSET utf8mb4
DEFAULTCOLLATE utf8mb4_unicode_ci;
如果不想设置一些属性,可直接用下面简单的语句即可:
CREATEDATABASE bookstore;
当看到
“Query OK, 1 row affected (0.32 sec);”
提示中,“Query OK”表示命令执行成功,“0.32 sec” 表示执行的时间。
2.2 查看所有数据库
实用语法
SHOW DATABASES [LIKE ‘数据库名’];
如:
第一个就是我们刚刚创建的bookstore
2.3 修改数据库
- 语法:
ALTERDATABASE[数据库名] {
[DEFAULT]CHARACTERSET<字符集名>|[DEFAULT]COLLATE<校对规则名>}
下面是一个实例 SQL 语句,用于修改一个名为 exampleDB 的数据库的默认字符集和校对规则
ALTERDATABASE exampleDB CHARACTERSET utf8mb4 COLLATE utf8mb4_unicode_ci;
这个 SQL 语句会将 exampleDB 的默认字符集和校对规则修改为 utf8mb4 和 utf8mb4_unicode_ci,同时保留该数据库中原有的数据。
- 还可以重命名数据库:
ALTERDATABASE exampleDB RENAMETO newDBName;
将名为 exampleDB 的数据库修改为名为 newDBName。需要注意的是,在修改数据库名称过程中,你需要关闭该数据库的所有连接,否则会报错。
2.4 删除数据库
- 语法
DROPDATABASE[IFEXISTS]<数据库名>
其中,database_name 表示要删除的数据库的名称。如果指定了 IF EXISTS,那么在删除一个不存在的数据库时,不会报错而是静默返回。
三、MySQL 数据表操作
数据表是数据库的重要组成部分,我们上面介绍了如何新建一个数据库。下面介绍表相关操作。
3.1 学习如何创建表
- 语法
CREATETABLE<表名>([表定义选项])[表选项][分区选项];CREATETABLE table_name (
column1 datatype [constraint],
column2 datatype [constraint],
column3 datatype [constraint],...PRIMARYKEY(one or more columns));
其中,table_name 表示要创建的表的名称。column1, column2, column3 等则表示表中的列名,datatype 表示该列的数据类型。如果不需要设置约束,则可以省略 [constraint]。PRIMARY KEY 用于指定表中的主键,可以需要设置一个或多个列作为主键,以保证表中的数据唯一性。
- 举例说明: 创建一个新的数据表,命名为 “books”,包括图书编号、图书名称、作者和价格:
CREATETABLE books(
id INT(11)NOTNULLAUTO_INCREMENT,
title VARCHAR(255)DEFAULTNULL,
author VARCHAR(255)DEFAULTNULL,
price DECIMAL(10,2)DEFAULTNULL,PRIMARYKEY(id));
3.2 学习如何删除表
- 语法
DROPTABLE[IFEXISTS] table_name;
其中,table_name 表示要删除的表的名称。如果指定了 IF EXISTS,那么在删除一个不存在的表时,不会报错而是静默返回。
- 举例说明:
删除名为 users 的数据库表
DROPTABLE users;
这个 SQL 语句会删除名为 users 的数据库表及其中的所有数据。
3.3 学习如何修改表结构
- 语法
ALTERTABLE<表名>[修改选项];
ALTERTABLE table_name
ADD[COLUMN] column_name data_type [NULL|NOTNULL][DEFAULT default_value][AFTER|FIRST column_name],DROP[COLUMN] column_name,MODIFY[COLUMN] column_name new_data_type [NULL|NOTNULL][DEFAULT default_value][FIRST|AFTER column_name],RENAME[COLUMN] old_column_name TO new_column_name,RENAMETO new_table_name;
参数比较多,其中,ADD 可以添加一个新的列,DROP 可以删除一个已经存在的列,MODIFY 可以修改一个已经存在的列的数据类型等属性,RENAME 可以重命名一个已经存在的列或者整个表。
- 举例说明:
添加一个新列 age 到一个名为 users 的表中
ALTERTABLE users ADDCOLUMN age INT(11)AFTER email;
删除一个名为 age 的列
ALTERTABLE users DROPCOLUMN age;
修改一个名为 username 的列的数据类型和默认值
ALTERTABLE users MODIFYCOLUMN username VARCHAR(100)NOTNULLDEFAULT'anonymous'AFTER id;
将一个名为 name 的列重命名为 full_name
ALTERTABLE users RENAMECOLUMN name TO full_name;
将一个名为 users 的表重命名为新名称 customers
ALTERTABLE users RENAMETO customers;
3.4 数据类型介绍和使用DATE、TIME、DATETIME和TIMESTAMP等时间数据类型
在 SQL 中,有许多不同的数据类型,包括数字类型、字符类型、日期时间类型等等。下面简要介绍一些常见的数据类型:
INT
/INTEGER
:整数类型VARCHAR
:可变长度字符串类型CHAR
:定长字符串类型TEXT
:文本字符串类型DECIMAL
/NUMERIC
:定点数类型FLOAT
/DOUBLE
:浮点数类型DATE
:日期类型,仅精确到日期TIME
:时间类型,仅精确到时分秒DATETIME
:日期时间类型,精确到毫秒TIMESTAMP
:时间戳类型,精确到秒
下面是使用不同时间数据类型的示例 SQL 语句:
- 使用
DATE
存储日期数据CREATETABLE sales ( id INT(11)NOTNULLAUTO_INCREMENT, customer_id INT(11)NOTNULL, order_date DATENOTNULL, total_amount DECIMAL(10,2)NOTNULL,PRIMARYKEY(id));``````order_date
列被指定为DATE
类型,因此它只精确到日期,而不包括时间。 - 使用
TIME
存储时间数据CREATETABLE employees ( id INT(11)NOTNULLAUTO_INCREMENT, name VARCHAR(50)NOTNULL, start_time TIMENOTNULL,PRIMARYKEY(id));
start_time列被指定为
TIME` 类型,因此它只精确到时分秒,而不包括日期。 - 使用
DATETIME
存储日期时间数据CREATETABLE log ( id INT(11)NOTNULLAUTO_INCREMENT, access_time DATETIMENOTNULL, user_id INT(11)NOTNULL,PRIMARYKEY(id));
access_time列被指定为
DATETIME` 类型,因此它包括日期和时间,精确到毫秒。 - 使用
TIMESTAMP
存储时间戳数据CREATETABLE bookings ( id INT(11)NOTNULLAUTO_INCREMENT, checkin_time TIMESTAMPNOTNULLDEFAULTCURRENT_TIMESTAMP, checkout_time TIMESTAMPNOTNULLDEFAULT'1970-01-01 00:00:01', room_id INT(11)NOTNULL,PRIMARYKEY(id));
checkin_time和
checkout_time列都被指定为
TIMESTAMP类型,因此它们包括日期和时间,精确到秒。其中,
checkin_time的默认值被设置为当前时间戳,
checkout_time的默认值被设置为
’1970-01-01 00:00:01’`,代表最小时间戳值。
需要注意的是,在不同的数据库管理系统中,时间数据类型可能会有所不同,例如
DATETIME
和
TIMESTAMP
的差异。此外,还需要仔细考虑如何处理时区、闰秒等问题。在实际使用中,建议参考相关的文档和标准,并遵守最佳实践。
3.5 如何使用SQL约束来保护数据的完整性
在 SQL 中,可以使用约束(Constraint)来限制或保护表中的数据完整性。这些约束包括列级约束和表级约束。
列级约束是针对单个列的约束,例如 NOT NULL、UNIQUE、PRIMARY KEY 和 FOREIGN KEY 约束。表级约束是针对多个列的约束,例如 CHECK 约束。
下面是一些常见的 SQL 约束以及如何使用它们来保护数据的完整性:
NOT NULL
约束:用于确保列中的值不为空。CREATETABLE Users ( ID INTNOTNULL, FirstName VARCHAR(50)NOTNULL, LastName VARCHAR(50)NOTNULL, Email VARCHAR(100)NOTNULL,CONSTRAINT PK_Users PRIMARYKEY(ID));``````ID
、FirstName
、LastName
和Email
列都被设置为NOT NULL
,以确保这些列中的值不能为空。UNIQUE
约束:用于确保列中的值是唯一的。CREATETABLE Products ( ID INTNOTNULL, Name VARCHAR(100)NOTNULL, Description TEXT, SKU VARCHAR(50)UNIQUE,CONSTRAINT PK_Products PRIMARYKEY(ID));``````SKU
列被设置为UNIQUE
,以确保每个产品都有唯一的 SKU 编号。PRIMARY KEY
约束:用于指定一个或多个列是表的主键,确保每行都有唯一的标识符。CREATETABLE Orders ( ID INTPRIMARYKEY, CustomerID INTNOTNULL, OrderDate DATETIMEDEFAULTNULL,CONSTRAINT FK_Orders_Customers FOREIGNKEY(CustomerID)REFERENCES Customers(ID));``````ID
列被设置为PRIMARY KEY
,以确保每个订单都有唯一的标识符。FOREIGN KEY
约束:用于确保列中的值与另一个表中的列的值匹配。CREATETABLE OrderDetails ( ID INTPRIMARYKEY, OrderID INTNOTNULL, ProductID INTNOTNULL, Quantity INTNOTNULL,CONSTRAINT FK_OrderDetails_Orders FOREIGNKEY(OrderID)REFERENCES Orders(ID),CONSTRAINT FK_OrderDetails_Products FOREIGNKEY(ProductID)REFERENCES Products(ID));
OrderID和
ProductID列都被设置为
FOREIGN KEY`,以确保订单详情行与订单和产品表中的正确行匹配。CHECK
约束:用于确保列中的值符合特定条件。CREATETABLE Employees ( ID INTPRIMARYKEY, FirstName VARCHAR(50)NOTNULL, LastName VARCHAR(50)NOTNULL, HireDate DATE, Salary DECIMAL(10,2)NOTNULL,CONSTRAINT CK_Employees_Salary CHECK(Salary >0));
Salary列被设置为
CHECK` 约束,以确保每个员工的工资大于 0。
通过使用约束,可以在 SQL 中保护数据的完整性和合法性。当尝试向表中插入或更新数据时,如果违反任何约束,则 SQL 将抛出错误,阻止事务的提交。
3.6 表的备份与恢复
在 SQL 中,我们可以使用备份和还原功能来保存和恢复数据库中的数据。
MySQL 数据库也提供了备份和恢复功能,可以使用
mysqldump
命令进行备份,使用
mysql
命令进行还原。下面是备份和恢复 MySQL 数据库表的语法及示例:
- 备份MySQL表
/*备份整个数据库*/ mysqldump -u root -p database_name > backup_file.sql /*备份单个表结构和数据*/mysqldump -u root -p database_name table_name > backup_file.sql /*备份单个表结构*/mysqldump -u root -p -d database_name table_name > backup_file.sql
在执行备份命令时,-u
表示登录 MySQL 数据库的用户名,-p
表示在输入密码时提示,database_name
表示需要备份的数据库名,table_name
表示需要备份的数据库表名。备份文件backup_file.sql
可以自行决定,同时也可以指定文件保存目录。 - 恢复MySQL表
/*从备份文件中还原整个数据库*/ mysql -u root -p database_name < backup_file.sql /*从备份文件中还原单个表结构和数据*/mysql -u root -p database_name < backup_file.sql /*从备份文件中还原单个表结构*/mysql -u root -p database_name < backup_file.sql
还原命令中的语法和备份命令大致相同,唯一的区别在于把备份文件作为标准输入来还原表格。在执行还原操作时,需要注意确保当前数据库表和备份文件中的表名和结构一致。
需要注意的是,MySQL 备份和恢复命令通常需要管理员权限,且执行时间较长,同时也需要考虑备份文件的安全和管理。在实际使用中,需要仔细考虑备份和恢复策略,并遵守相关的数据库安全和最佳实践。
版权归原作者 Android西红柿 所有, 如有侵权,请联系我们删除。