首页 > 数据库 >MySQL基础篇:掌握数据表操作的基础知识

MySQL基础篇:掌握数据表操作的基础知识

时间:2023-09-03 10:05:00浏览次数:41  
标签:varchar mysql 基础知识 数据表 student MySQL YES NULL id

MySQL基础篇:掌握数据表操作的基础知识_表


表(table)是一种结构化的文件,可以用来存储特定类型的数据,如:学生信息,课程信息,都可以放到表中。另外表都有特定的名称,而且不能重复。表中具有几个概念:列、行、主键。 列叫做字段(Column),行叫做表中的记录,每一个字段都有:字段名称/字段数据类型/字段约束/字段长度

创建表

在 MySQL 中,可以使用 CREATE TABLE 语句创建表。其语法格式为:

create table tableName(
columnName dataType(lenght),
.....
columnName dataType(lenght)
);
set character_set_results='gbk'

创建表的时候,表中有字段,每一个字段有:

     * 字段名

     * 字段数据类型

     * 字段长度限制

     * 字段约束

MySql常用数据类型

类型

描述

Char(长度)

定长字符串,存储空间大小固定,适合作为主键或外键

Varchar(长度)

变长字符串,存储空间等于实际数据空间

double(有效数字位数,小数位)

数值型

Float(有效数字位数,小数位)

数值型

Int( 长度)

整型

bigint(长度)

长整型

Date

日期型 年月日

DateTime

日期型 年月日 时分秒 毫秒

time

日期型 时分秒

BLOB

Binary Large OBject(二进制大对象)

CLOB

Character Large OBject(字符大对象)

其它…………………

 

例子: 建立学生信息表,字段包括:学号、姓名、性别、出生日期、email、班级标识。

mysql> create table t_student(
    -> student_id int(10),
    -> student_name varchar(20),
    -> sex char(2),
    -> birthday date,
    -> email varchar(30),
    -> classes_id int(3)
    -> );
Query OK, 0 rows affected (0.18 sec)
mysql> desc t_student;
+--------------+-------------+------+-----+---------+-------+
| Field        | Type        | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| student_id   | int(10)     | YES  |     | NULL    |       |
| student_name | varchar(20) | YES  |     | NULL    |       |
| sex          | char(2)     | YES  |     | NULL    |       |
| birthday     | date        | YES  |     | NULL    |       |
| email        | varchar(30) | YES  |     | NULL    |       |
| classes_id   | int(3)      | YES  |     | NULL    |       |
+--------------+-------------+------+-----+---------+-------+
6 rows in set (0.22 sec)

增加/删除/修改表结构

采用alter table来增加/删除/修改表结构,不影响表中的数据。

添加字段

如:需求发生改变,需要向t_student中加入联系电话字段,字段名称为:contatct_tel 类型为varchar(40)。

mysql> alter table t_student add contact_tel varchar(40);
Query OK, 0 rows affected (0.15 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc t_student;
+--------------+-------------+------+-----+---------+-------+
| Field        | Type        | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| student_id   | int(10)     | YES  |     | NULL    |       |
| student_name | varchar(20) | YES  |     | NULL    |       |
| sex          | char(2)     | YES  |     | NULL    |       |
| birthday     | date        | YES  |     | NULL    |       |
| email        | varchar(30) | YES  |     | NULL    |       |
| classes_id   | int(3)      | YES  |     | NULL    |       |
| contact_tel  | varchar(40) | YES  |     | NULL    |       |
+--------------+-------------+------+-----+---------+-------+
7 rows in set (0.21 sec)

修改字段

如:student_name无法满足需求,长度需要更改为100。

mysql> alter table t_student modify student_name varchar(100);
Query OK, 0 rows affected (0.10 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc t_student;
+--------------+--------------+------+-----+---------+-------+
| Field        | Type         | Null | Key | Default | Extra |
+--------------+--------------+------+-----+---------+-------+
| student_id   | int(10)      | YES  |     | NULL    |       |
| student_name | varchar(100) | YES  |     | NULL    |       |
| sex          | char(2)      | YES  |     | NULL    |       |
| birthday     | date         | YES  |     | NULL    |       |
| email        | varchar(30)  | YES  |     | NULL    |       |
| classes_id   | int(3)       | YES  |     | NULL    |       |
| contact_tel  | varchar(40)  | YES  |     | NULL    |       |
+--------------+--------------+------+-----+---------+-------+
7 rows in set (0.18 sec)

如sex字段名称感觉不好,想用gender那么就需要更爱列的名称

mysql> alter table t_student change sex gender char(2);
Query OK, 0 rows affected (0.12 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc t_student;
+--------------+--------------+------+-----+---------+-------+
| Field        | Type         | Null | Key | Default | Extra |
+--------------+--------------+------+-----+---------+-------+
| student_id   | int(10)      | YES  |     | NULL    |       |
| student_name | varchar(100) | YES  |     | NULL    |       |
| gender       | char(2)      | YES  |     | NULL    |       |
| birthday     | date         | YES  |     | NULL    |       |
| email        | varchar(30)  | YES  |     | NULL    |       |
| classes_id   | int(3)       | YES  |     | NULL    |       |
| contact_tel  | varchar(40)  | YES  |     | NULL    |       |
+--------------+--------------+------+-----+---------+-------+
7 rows in set (0.19 sec)

删除字段

如:删除联系电话字段。

mysql> alter table t_student drop contact_tel;
Query OK, 0 rows affected (0.09 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc t_student;
+--------------+--------------+------+-----+---------+-------+
| Field        | Type         | Null | Key | Default | Extra |
+--------------+--------------+------+-----+---------+-------+
| student_id   | int(10)      | YES  |     | NULL    |       |
| student_name | varchar(100) | YES  |     | NULL    |       |
| gender       | char(2)      | YES  |     | NULL    |       |
| birthday     | date         | YES  |     | NULL    |       |
| email        | varchar(30)  | YES  |     | NULL    |       |
| classes_id   | int(3)       | YES  |     | NULL    |       |
+--------------+--------------+------+-----+---------+-------+
6 rows in set (0.19 sec)

数据库增删改

添加、修改和删出都属于DML,主要包含的语句:insert、update、delete

增(insert)

INSERT VALUES 的语法格式为:

INSERT INTO <表名> [ <列名1> [ , … <列名n>] ]
VALUES (值1) [… , (值n) ];

语法说明如下。

  • <表名>:指定被操作的表名。
  • <列名>:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。
  • VALUESVALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

省略字段的插入

mysql> insert into EMP values(9999,'zhangsan','MANAGER',null,null,3000,500,10);
Query OK, 1 row affected (0.09 sec)
mysql> select * from EMP where EMPNO=9999;
+-------+----------+---------+------+----------+---------+--------+--------+
| EMPNO | ENAME    | JOB     | MGR  | HIREDATE | SAL     | COMM   | DEPTNO |
+-------+----------+---------+------+----------+---------+--------+--------+
|  9999 | zhangsan | MANAGER | NULL | NULL     | 3000.00 | 500.00 |     10 |
+-------+----------+---------+------+----------+---------+--------+--------+
1 row in set (0.24 sec)

mysql>

不建议使用此种方式,因为当数据库表中的字段位置发生改变的时候会影响到insert语句.

指定字段的插入(建议使用此种方式)

mysql> insert into EMP (EMPNO,ENAME,JOB,SAL,COMM,DEPTNO) values(9998,'lisi','MANAGER',4000,300,10);
Query OK, 1 row affected (0.08 sec)

mysql> select * from EMP where EMPNO=9998;
+-------+-------+---------+------+----------+---------+--------+--------+
| EMPNO | ENAME | JOB     | MGR  | HIREDATE | SAL     | COMM   | DEPTNO |
+-------+-------+---------+------+----------+---------+--------+--------+
|  9998 | lisi  | MANAGER | NULL | NULL     | 4000.00 | 300.00 |     10 |
+-------+-------+---------+------+----------+---------+--------+--------+
1 row in set (2.53 sec)

表复制

mysql> create table emp_bak as select EMPNO,ENAME,SAL from EMP;
Query OK, 16 rows affected (0.11 sec)
Records: 16  Duplicates: 0  Warnings: 0

mysql> select * from emp_bak;
+-------+----------+---------+
| EMPNO | ENAME    | SAL     |
+-------+----------+---------+
|  7369 | SMITH    |  800.00 |
|  7499 | ALLEN    | 1600.00 |
|  7521 | WARD     | 1250.00 |
|  7566 | JONES    | 2975.00 |
|  7654 | MARTIN   | 1250.00 |
|  7698 | BLAKE    | 2850.00 |
|  7782 | CLARK    | 2450.00 |
|  7788 | SCOTT    | 3000.00 |
|  7839 | KING     | 5000.00 |
|  7844 | TURNER   | 1500.00 |
|  7876 | ADAMS    | 1100.00 |
|  7900 | JAMES    |  950.00 |
|  7902 | FORD     | 3000.00 |
|  7934 | MILLER   | 1300.00 |
|  9998 | lisi     | 4000.00 |
|  9999 | zhangsan | 3000.00 |
+-------+----------+---------+
16 rows in set (0.27 sec)


删除(delete)

使用 DELETE 语句从单个表中删除数据,语法格式为:

DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

语法说明如下:

  • <表名>:指定要删除数据的表名。
  • ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
  • WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
  • LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

改(update)

使用 UPDATE 语句修改单个表,语法格式为:

UPDATE <表名> SET 字段 1=值 1 [,字段 2=值 2… ] [WHERE 子句 ]
[ORDER BY 子句] [LIMIT 子句]

语法说明如下:

  • <表名>:用于指定要更新的表名称。
  • SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。
  • WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
  • ORDER BY 子句:可选项。用于限定表中的行被修改的次序。
  • LIMIT 子句:可选项。用于限定被修改的行数。

将job为manager的员工的工资上涨10%。

mysql> update EMP set SAL=SAL+SAL*0.1 where JOB='MANAGER';
Query OK, 5 rows affected (0.08 sec)
Rows matched: 5  Changed: 5  Warnings: 0

创建表加入约束

常见的约束

  • 非空约束(not null)
  • 唯一约束(unique)
  • 主键约束(primary key)
  • 外键约束(foreign key)
  • 自定义检查约束,check(不建议使用)(在mysql中现在还不支持)


非空约束(not null)

非空约束,针对某个字段设置其值不为空,如:学生的姓名不能为空。

mysql> drop table if exists t_student; 
mysql> create table t_student(
    -> student_id int(10),
    -> student_name varchar(20) not null,
    -> sex char(2),
    -> birthday date,
    -> email varchar(30),
    -> classes_id int(3)
    -> );
Query OK, 0 rows affected (0.18 sec)

唯一约束(unique)

唯一性约束,它可以使某个字段的值不能重复,如:email不能重复:

mysql> drop table if exists t_student; 
mysql> create table t_student(
    -> student_id int(10),
    -> student_name varchar(20) not null,
    -> sex char(2),
    -> birthday date,
    -> email varchar(30) unique,
    -> classes_id int(3)
    -> );
Query OK, 0 rows affected (0.18 sec)

主键约束(primary key)

每个表应该具有主键,主键可以标识记录的唯一性,主键分为单一主键和复合(联合)主键,单一主键是由一个字段构成的,复合(联合)主键是由多个字段构成的。

mysql> drop table if exists t_student; 
mysql> create table t_student(
    -> student_id int(10) primary key,/*列级约束*/
    -> student_name varchar(20) not null,
    -> sex char(2),
    -> birthday date,
    -> email varchar(30) unique,
    -> classes_id int(3)
    -> );
Query OK, 0 rows affected (0.18 sec)

或者是在定义完所有字段之后指定主键,语法格式如下:

[CONSTRAINT <约束名>] PRIMARY KEY [字段名]

我们也可以通过表级约束为约束起个名称:

mysql> drop table if exists t_student; 
mysql> create table t_student(
    -> student_id int(10)
    -> student_name varchar(20) not null,
    -> sex char(2),
    -> birthday date,
    -> email varchar(30) unique,
    -> classes_id int(3),
    -> CONSTRAINT p_id primary key(student_id)
    -> );
Query OK, 0 rows affected (0.18 sec)

外键约束(foreign key)

外键主要是维护表之间的关系的,主要是为了保证参照完整性,如果表中的某个字段为外键字段,那么该字段的值必须来源于参照的表的主键,如:emp中的deptno值必须来源于dept表中的deptno字段值。

建立学生和班级表之间的连接。

首先建立班级表t_classes

mysql> drop table if exists t_classes;
Query OK, 0 rows affected (0.55 sec)

mysql> create table t_classes(
    -> classes_id int(3),
    -> classes_name varchar(40),
    -> constraint pk_classes_id primary key(classes_id)
    -> );
Query OK, 0 rows affected (0.16 sec)

在t_student中加入外键约束

mysql> drop table if exists t_student;
Query OK, 0 rows affected (0.11 sec)
mysql> create table t_student(
    -> student_id int(10)
    -> student_name varchar(20) not null,
    -> sex char(2),
    -> birthday date,
    -> email varchar(30) unique,
    -> classes_id int(3),
    -> CONSTRAINT p_id primary key(student_id),
    -> CONSTRAINT fk_class_id foreign  key(classes_id)
    -> );


标签:varchar,mysql,基础知识,数据表,student,MySQL,YES,NULL,id
From: https://blog.51cto.com/feng1992/7336910

相关文章

  • 【专题】2023AIGC人才供需报告PDF合集分享(附原数据表)
    原文链接:https://tecdat.cn/?p=33544自2022年11月ChatGPT发布以来,其超出预期的“涌现”能力彻底点燃了AIGC赛道。从人力资源角度来看,AIGC相关职位数量明显增加,并且人才对于这些职位的投递也更加积极。阅读原文,获取专题报告合集全文,解锁文末190份AIGC行业相关报告。值得注意的是,A......
  • 【专题】2023年中国AIGC产业全景报告PDF合集分享(附原数据表)
    原文链接:https://tecdat.cn/?p=33544自2022年11月ChatGPT发布以来,其超出预期的“涌现”能力彻底点燃了AIGC赛道。从人力资源角度来看,AIGC相关职位数量明显增加,并且人才对于这些职位的投递也更加积极。阅读原文,获取专题报告合集全文,解锁文末190份AIGC行业相关报告。值得注意的是,A......
  • 纯分享:将MySql的建表DDL转为PostgreSql的DDL
    背景现在信创是搞得如火如荼,在这个浪潮下,数据库也是从之前熟悉的Mysql换到了某国产数据库。该数据库我倒是想吐槽吐槽,它是基于Postgre9.x的基础上改的,至于改了啥,我也没去详细了解,当初的数据库POC测试和后续的选型没太参与,但对于我一个开发人员的角度来说,它给我带来的不便主要是......
  • MySQL添加用户并授权
    执行前要确认,授权给这个用户的数据库已经被创建好createdatabase库名charactersetutf8mb4;接下来,可以采用直接授权的方式,能够同时创建用户以及授权grantselect,insert,delete,update,createon库名.*to'用户名'@'%'identifiedby'密码';......
  • 重复索引检查mysql pt-duplicate-key-checker
    索引对于优化数据库中的查询执行时间至关重要,但是索引数量过多或冗余会对性能产生负面影响。虽然pt-duplicate-key-checker是识别MySQL中重复或冗余索引的首选工具,但它可能无法捕获所有重复。测试环境,mysql5.7.27建表结mysql[localhost:5727]{root}(sbtest)>CREATETABLE`sbt......
  • MYSQL数据库备份还原,并还原到最新状态(mysqldump)
    启用二进制日志文件vim/etc/my.cnf配置文件位置及文件名根据实际情况确定<br>sql_log_bin=on|off:是否记录二进制日志,默认为on在需要的时候设置为off=""<br>log_bin="/PATH/BIN_LOG_FILE:指定二进制日志文件位置;"通常单独存放到与数据库不同的机器中=""<=""p=""></br>......
  • IPV6配置mysql
    一、mysql参数影响mysql配置文件my.cnf可以配置一个参数bind-address该参数默认为*,意思是全网监听(可以是ipv4也可以是ipv6)如果该参数设置成ipv4地址,则mysql的3306端口监听ipv4地址如果该参数设置生ipv6地址,则mysql的3306端口监听ipv6地址二、mysql主从配置CHANGEMASTERTO......
  • MySQL的基本语句
    目录1.0数据库操作2.0数据表操作2.1表的创建2.2表的修改2.2.1表中字段的添加2.2.2表中字段的修改2.2.3表中字段的删除2.3表的查询2.3.1查询数据库中所有的表2.3.2查询表结构2.4表的删除2.5表中数据的操作2.5.1表数据的查询2.5.1.1表中数据的简单查询2.5.1.2表中数据......
  • CentOS6.5安装mysql 远程登录
    第1步、yum安装mysql[[email protected]]#yum-yinstallmysql-server直到出现结果: 第2步、设置开机启动[[email protected]]#chkconfigmysqldon这步没提示第3步、启动mysql服务[[email protected]]#servicemysqldstartshell提示: 第4步、修改r......
  • mysql索引(转)
    转载:https://www.php.cn/faq/493277.html一、数据结构区分1.1.B+tree索引根据存储方式,mysql可以分为B+tree索引和哈希索引B+tree索引可以进行全键值、键值范围和键值前缀查询1.2.哈希索引哈希索引也称为散列索引或 HASH索引。MySQL目前仅有MEMORY存储引擎和HEAP存......