2 - 表结构 | MySQL键值

表结构 | MySQL键值

  • 表管理
    • 1. 库的操作
    • 2. 表的操作
      • 表的创建与删除
      • 表的修改
      • 复制表
    • 3. 管理表记录
  • 数据类型
    • 数值类型
    • 字符类型(汉字或者英文字母)
    • 日期时间类型 表头存储与日期时间格式的数据
    • 枚举类型
  • 数据批量处理

表管理

客户端把数据存储到数据库服务器上的过程

  • 第一步连接数据库
  • 第二步创建存储数据的库(存放表的目录)
  • 第三步创建存储数据的表(表就是存储数据的文件)
  • 第四步插入表记录(向文件里添加行)
  • 第五步断开连接

1. 库的操作

建库的基本命令 create database 库名(必须唯一性!!!)

[root@host50 ~]# mysql -uroot -pxxxx  //数据库管理员登陆
mysql> select user(); # 查看登陆的用户
+----------------+
| user()         |
+----------------+
| root@localhost |  用户@客户端地址 (在本机管理员登录)
+----------------+
1 row in set (0.00 sec)mysql> show databases; # 查看已有的库
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| tarena             |
+--------------------+
5 rows in set (0.00 sec)mysql> select database(); # 查看当前所在的库
+------------+
| database() |
+------------+
| NULL       |  表示没有在任何一个库,此时所在的位置是/var/lib/mysql 目录
+------------+
1 row in set (0.00 sec)mysql> create database db1 # 创建新库
Query OK, 1 row affected (0.00 sec)mysql> show databases;  此时查看已有库
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db1                |      刚创建的db1库 , 在数据库目录/var/lib/myql 下会有对应名称的db1目录
| mysql              |
| performance_schema |
| sys                |
| tarena             |
+--------------------+
6 rows in set (0.00 sec)mysql> system ls -ld /var/lib/mysql/db1; # 使用system 命令 在登录状态下执行系统命令
drwxr-x--- 2 mysql mysql 20 97 13:52 /var/lib/mysql/db1mysql>  create database if not exists  DB1; 加if not exists语句避免重名报错 
Query OK, 1 row affected, 1 warning (0.01 sec)// 删除库 如果库里有表会一并被删除
mysql> drop database db1 ; 删除没有的库,会报错
mysql> drop database  if exists db1;  加if  exists 语句 避免报错

2. 表的操作

建表命令格式
create table 库名.表名(
表头名 数据结构 [约束条件],
表头名 数据结构 [约束条件]
);

表的创建与删除

使用建表范式衡量表创建的是否合理

  • 1NF 表头下的数据不能再拆分
  • 2NF 一张表里只存储一种数据信息,不能用一张存储多种数据信息
  • 3NF 表中表头的数据 不能依赖其他表头的数据
mysql> create table DB1.t1(姓名 char(10),班级 char(7)); # 在DB1库里创建t1表mysql> desc DB1.t1; 查看表头信息
+--------+----------+------+-----+---------+-------+
| Field  | Type     | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+-------+
| 姓名   | char(10) | YES  |     | NULL    |       |
| 班级   | char(7)  | YES  |     | NULL    |       |
+--------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)mysql> drop table DB1.t1;  删除创建的表
Query OK, 0 rows affected (0.11 sec)为了便于操作通常使用英文定义表头名和表名
mysql> create table DB1.t1 ( name  char(15) , class char(10));
Query OK, 0 rows affected (0.25 sec)
mysql> desc DB1.t1; 查看表头
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| name  | char(15) | YES  |     | NULL    |       |
| class | char(10) | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

表的修改

发现表建的不合理 可以修改表

  • 添加新表头 add
  • 删除表头 drop
  • 修改表头存储数据的数据类型 modify
  • 修改表头名 change
  • 修改表名 rename
    alter table 库名.表名 操作命令
mysql> alter table  DB1.t1 add school  char(20) ; 添加1个新字段school
mysql> desc DB1.t1;  默认新添加的字段追加在已有列的末尾
+--------+----------+------+-----+---------+-------+
| Field  | Type     | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+-------+
| name   | char(15) | YES  |     | NULL    |       |
| class  | char(10) | YES  |     | NULL    |       |
| school | char(20) | YES  |     | NULL    |       |
+--------+----------+------+-----+---------+-------+
3 rows in set (0.00 sec)一起添加2个字段 分别是 mail 和  address 
mysql> alter table  DB1.t1 add mail char(50) , add address  char(80) ;
Query OK, 0 rows affected (0.37 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> desc DB1.t1;  查看新添加的表头,都在追加在末尾
+---------+----------+------+-----+---------+-------+
| Field   | Type     | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| name    | char(15) | YES  |     | NULL    |       |
| class   | char(10) | YES  |     | NULL    |       |
| school  | char(20) | YES  |     | NULL    |       |
| mail    | char(50) | YES  |     | NULL    |       |
| address | char(80) | YES  |     | NULL    |       |
+---------+----------+------+-----+---------+-------+
5 rows in set (0.00 sec)添加新表头number 在第1列的位置
mysql> alter table  DB1.t1 add number int first ;
Query OK, 0 rows affected (0.32 sec)
Records: 0  Duplicates: 0  Warnings: 0
添加新表头在city 放在name的后边
mysql> alter table DB1.t1 add  city  char(10) after name;
Query OK, 0 rows affected (0.42 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> desc DB1.t1;
+---------+----------+------+-----+---------+-------+
| Field   | Type     | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| number  | int(11)  | YES  |     | NULL    |       |
| name    | char(15) | YES  |     | NULL    |       |
| city    | char(10) | YES  |     | NULL    |       |
| class   | char(10) | YES  |     | NULL    |       |
| school  | char(20) | YES  |     | NULL    |       |
| mail    | char(50) | YES  |     | NULL    |       |
| address | char(80) | YES  |     | NULL    |       |
+---------+----------+------+-----+---------+-------+
7 rows in set (0.00 sec)mysql> alter table DB1.t1 drop city;  一次删除一个表头
Query OK, 0 rows affected (0.31 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> alter table DB1.t1 drop class , drop school; 一起删除多个表头
Query OK, 0 rows affected (0.32 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> desc DB1.t1;  查看表头
+---------+----------+------+-----+---------+-------+
| Field   | Type     | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| number  | int(11)  | YES  |     | NULL    |       |
| name    | char(15) | YES  |     | NULL    |       |
| mail    | char(50) | YES  |     | NULL    |       |
| address | char(80) | YES  |     | NULL    |       |
+---------+----------+------+-----+---------+-------+
4 rows in set (0.00 sec)// 修改表头信息
mysql> alter table DB1.t1 modify number tinyint after name; 修改类型和位置
mysql> desc DB1.t1;  查看修改,把类型修改为tinyint  并移动name表头的后边
+---------+------------+------+-----+---------+-------+
| Field   | Type       | Null | Key | Default | Extra |
+---------+------------+------+-----+---------+-------+
| name    | char(15)   | YES  |     | NULL    |       |
| number  | tinyint(4) | YES  |     | NULL    |       |
| mail    | char(50)   | YES  |     | NULL    |       |
| address | char(80)   | YES  |     | NULL    |       |
+---------+------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 change address homedir char(80); 只修改表头名,类型原样抄下来
Query OK, 0 rows affected (0.05 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> desc DB1.t1;查看修改,address 修改为了 homedir
+---------+------------+------+-----+---------+-------+
| Field   | Type       | Null | Key | Default | Extra |
+---------+------------+------+-----+---------+-------+
| name    | char(15)   | YES  |     | NULL    |       |
| number  | tinyint(4) | YES  |     | NULL    |       |
| mail    | char(50)   | YES  |     | NULL    |       |
| homedir | char(80)   | YES  |     | NULL    |       |
+---------+------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 change email vachar(60); 表头名和类型一起修改
Query OK, 0 rows affected (0.44 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> desc DB1.t1;查看修改表头名类型都变了
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name    | char(15)    | YES  |     | NULL    |       |
| number  | tinyint(4)  | YES  |     | NULL    |       |
| email   | varchar(60) | YES  |     | NULL    |       |
| homedir | char(80)    | YES  |     | NULL    |       |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 rename stuinfo; 修改表名为 stuinfo
mysql> show tables; 查看表名 已经改变
+---------------+
| Tables_in_DB1 |
+---------------+
| stuinfo       |
+---------------+

复制表

  • 仅复制表结构
mysql> create table DB1.t2 select * from tarena.user where 1=2 ; 复制表结构及数据
  • 复制表结构和数据
mysql> create table DB1.t3 select * from tarena.user 
  • 仅复制表结构
create table 库.表名 like 库.表名
# 原来的key也会复制给新表 复制不了数据

3. 管理表记录

对表中存储的行做管理 操作 包括

  • 查询 : 查看表中的行 select
  • 插入 : 向表中添新的行 insert into
添加1行给所有表头赋值
mysql> insert into DB1.stuinfo  values ("yaya",1,"yaya@tedu.cn","beijing");
Query OK, 1 row affected (0.03 sec)添加1行 ,给指定的表头赋值,
mysql> insert into DB1.stuinfo (name,homedir)values("nb","nb@tedu.cn");
Query OK, 1 row affected (0.04 sec)没有赋值的表头number和email 没有数据 ,值是 null (空)
mysql> select  * from DB1.stuinfo;
+------+--------+--------------+-------------+
| name | number | email        | homedir     |
+------+--------+--------------+-------------+
| yaya |      1 | yaya@tedu.cn | beijing     |
| plj  |      8 | plj@163.com  | shanghai    |
| jing |      9 | jing@163.com | beijing     |
| nb   |   NULL | NULL         | nb@tedu.cn  |
| nb2  |   NULL | NULL         | nb2@tedu.cn |
| nb3  |   NULL | NULL         | nb3@tedu.cn |
+------+--------+--------------+-------------+
6 rows in set (0.00 sec)使用set语句插入记录 
mysql> insert into  DB1.stuinfo set name="plj" , number=10;
  • 更新 : 修改行中列的数据 update
mysql> update DB1.stuniof set email="stu@163.com" where email is null;不加条件批量修改
mysql> update DB1.stuinfo set homedir="beijing";
  • 删除 : 删除表中的行 delete
// 只删除与条件符合的行 
delete from DB1.stuinfo where name regexp '^nb';//删除表里的所有行
delete from 库.表也可用truncate table 库.表;
自增长列 truncate后从1开始 delete继续变好
truncate不能回滚 delete可以
效率略高于delete 

数据类型

包括 数值类型、字符类型、日期时间类型、枚举类型

数值类型

  • 整数类型
    在这里插入图片描述
  • 浮点类型
    在这里插入图片描述

字符类型(汉字或者英文字母)

  • char 定长 (固定长度) 1-255字节
  • varchar 变长 (长度不固定) 1-65535
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    默认不允许给表头存储中文 要存储中文 要指定使用的字符集
mysql> show create table db1.t3  # 查看字符集
ENGINE=InnoDB # 定义存储引擎
DEFAULT CHARSET =latin1 # 定义字符集# 建表的时候指定使用的字符集
create table db1.t4(姓名 char(3),地址 varchar(10)) DEFAULT CHARSET utf8;

日期时间类型 表头存储与日期时间格式的数据

在这里插入图片描述

mysql> create table db1.t6(
姓名 char(4),
生日 date,
上课时间 time,
家庭聚会 datetime,
聚会地点 varchar(10)
) DEFAULT CHARSET utf8;mysql> alter table db1.t6 add 出生年份 year after 姓名;

在这里插入图片描述
datetime 与 datestamp的区别

  • 第一个存储范围不一样(datetime存储范围大 timestamp范围小)
  • 存储数据的方式不一样 当未给timestamp字段值 自动以当前系统时间赋值,而datetime值为NULL

枚举类型

给表头赋值时,值必须在类型规定的范围内选择

  • 单选 enum (值1,值2,值3…)
  • 多选 set (值1,值2,值3…)
create table db1.t8(姓名 char(10) , 性别  enum("男","女","保密") ,
爱好 set("帅哥","金钱");

数据批量处理

一次性向表里存储很多数据 或 一次性把表里的数据都取出来
注意:数据导入或导出 存放数据的文件必须在mysql服务要求的目录下 叫检索目录

要知道数据库默认的检索目录
会修改数据库默认的检索目录
查看默认的检索目录

mysql > show variables like "secure_file_priv"

在这里插入图片描述
修改默认的检索目录

vim /etc/my.cnf
[mysql]
secure_file_priv=/myload # 手动添加
mkdir /myload
chown mysql /myload/ # 给权限
  • 数据导入(文件的内容一定要有规律)
    • 将/etc/passwd文件导入db1库的t3表里
    • 文件导入格式
    • mysql> load data infile “/检索目录/文件名” into table 库名.表名 fileds terminated by "文件中列的间隔符号 " lines terminated by “/n”
    • 数据导入的操作步骤:
        1. 创建存储数据的库
        1. 根据导入文件的内容 建表
        1. 把系统文件拷贝到检索目录
        1. 数据库管理执行导入数据的命令
        1. 查看数据
  • 数据导出 导出的不包括表头名 只有表里的行 导出的文件名 不需要事先创建 且具有唯一性
      1. select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名”
      1. select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名” fields terminated by “符号”
      • fields terminated by 指定导出的列在文件中的间隔符号。不止定 默认时一个tab的宽度
      1. select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名” fields terminated by “符号” lines terminated by “符号”
      • lines terminated by 指定导出的行在文件中的间隔符号。不止定 默认一条记录就是一行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/590402.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开始使用MEVN技术栈开发01 概述

开始使用MEVN技术栈开发01 概述 简介 Welcome to Beginning MEVN Stack! This book focuses on the key tasks and concepts to get you started to learn and build MEVN stack applications in a faster pace. 欢迎阅读《MEVN堆栈入门》!本书重点介绍关键任务…

C语言指针使用常见问题

1.*p&#xff1a; #include<stdio.h> int main() {char s[ ]"159",*p;ps;printf("%c",*p);printf("%c",*p);return 0; } 输出&#xff1a;15 注意点&#xff1a;根据符号的优先级&#xff0c;*p与*(p)可以等价 2.指针的初始化&#x…

黑豹程序员-vue3下载文件

原理 vue3利用在页面中动态创建a标签&#xff0c;设置a标签属性&#xff0c;触发a标签的click实现文件下载。 代码 在前端工程的public资源目录下&#xff0c;创建template模板文件目录&#xff0c;把要下周的模板文件放入&#xff1a;product-dir.xlsx <el-button type&…

Serverless Framework:开发无服务器应用的最佳工具 | 开源日报 No.133

serverless/serverless Stars: 45.6k License: MIT 该项目是 Serverless Framework&#xff0c;它是一个命令行工具&#xff0c;使用简单易懂的 YAML 语法部署代码和云基础设施以满足各种无服务器应用程序需求。支持 Node.js、Typescript、Python、Go 等多种编程语言&#xff…

【AI】人类视觉感知特性与深度学习模型(1/2)

目录 一、关于人类视觉感知 1.1 视觉关注 1.自上而下&#xff08;Top-down&#xff09;的视觉关注 ​编辑 2.自下而上&#xff08;Bottom-up&#xff09;的视觉关注 3.区别和记忆点 1.2 视觉掩盖 1.常见的视觉掩盖效应 2.恰可识别失真&#xff08;Just Noticeable Dif…

WPF 基础入门 (Binding 一)

1 通知机制 WPF 中Binding可以比作数据的桥梁&#xff0c;桥梁的两端分别是Binding的源&#xff08;Source&#xff09;和目标&#xff08;Target&#xff09;。一般情况下&#xff0c;Binding源是逻辑层对象&#xff0c;Binding目标是UI层的控件对象&#xff0c;这样&#xff…

概念解析 | Shapley值及其在深度学习中的应用

注1:本文系“概念解析”系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:Shapley值及其在深度学习中的应用。 1 背景介绍 在机器学习和数据分析中,理解模型的预测是非常重要的。尤其是在深度学习黑盒模型中,我们往往难以直观地理解模型的预测行为。为…

软件测试/测试开发丨接口测试之Postman 安装与使用

Postman 安装 官网下载地址 www.postman.com/downloads Postman 使用 发送get请求 新建请求 填写请求方式&#xff1a;GET 填写请求 URL&#xff1a; ceshiren.com/httpbin.ceshiren.com/get 填写请求参数&#xff1a; para_key para_value 发送 POST 请求 请求方式&…

1. Spring概述

概述 Spring 是一个开源框架Spring 为简化企业级开发而生&#xff0c;使用 Spring&#xff0c;JavaBean 就可以实现很多以前要靠 EJB 才能实现的功能。同样的功能&#xff0c;在 EJB 中要通过繁琐的配置和复杂的代码才能够实现&#xff0c;而在 Spring 中却非常的优雅和简洁。…

2023年总结(2023年1月1日至2023年12月31日)

前言 时间过得真快啊&#xff0c;一年又过去了。 从去年11月换了家公司后&#xff0c;工作就稳定多了&#xff0c;做的工作也是我喜欢做的工作——摄像头驱动&#xff0c;平时也挺轻松的&#xff0c;偶尔有事儿的时候会压力大点&#xff0c;加点班&#xff0c;其他都还好&…

4年微博热搜数据,一次拿走

又是新的一年了&#xff0c;从2020年开始&#xff0c;就养成了定时备份各大平台热搜数据的习惯&#xff0c;微博&#xff0c;知乎都在备份&#xff0c;今天给大家看一下从2020年到2023年的微博热搜数据情况 这是2022年的备份数据&#xff0c;每天的热搜数据一个文件&#xff0c…

2.2 设计FMEA步骤二:结构分析

2.2.1 目的 设计结构分析的目的是将设计识别和分解为系统、子系统、组件和零件,以便进行技术风险分析。其主要目标包括: 可视化分析范围结构化表示:方块图、边界图、数字模型、实体零件识别设计接口、交互作用和间隙促进顾客和供应商工程团队之间的协作(接口责任)为功能分…

计算机组成原理——中央处理器cpu21-40

18、某计算机的指令流水线由4个功能段组成&#xff0c;指令流经各功能段的时间&#xff08;忽略各功能段之间的缓存时间&#xff09;分别为90ns、80ns、70ns和60ns&#xff0c;则该计算机的CPU时钟周期至少是多少。A A、 90ns     B、 80ns C、 70ns     D、 60ns …

修改docker镜像IP

1.创建网络 docker network create --driver bridge --subnet 100.168.0.0/24 my_network2.修改docker-compose启动文件 version: "2" services:situation-awareness-web:restart: alwaysimage: situation-awareness-web:0.1.0container_name: situation-awareness…

【日常聊聊】解决深度学习模型挑战:解释性与鲁棒性的平衡

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; 日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 1. 数据偏见&#xff1a; 介绍和解释&#xff1a; 解决方法&#xff1a; 2. 复制训练数据&#xff1a; 介绍和解决方法&am…

git 查看最新commit提交时间(具体到时分秒)

git 查看最新commit提交时间 使用服务器时间 以及如何自定义显示格式 使用服务器时间查看最新提交时间&#xff1a; 可以使用 git log 命令来查看最新提交的时间&#xff0c;该时间默认显示为作者提交时间。 $ git log -1 --format"%cd"如果想查看提交者提交时间&a…

【形式语言与自动机/编译原理】CFG-->Greibach-->NPDA(2)

本文将详细讲解《形式语言与自动机》&#xff08;研究生课程&#xff09;或《编译原理》&#xff08;本科生课程&#xff09;中的上下文无关文法&#xff08;CFG&#xff09;转换成Greibach范式&#xff0c;再转成下推自动机&#xff08;NPDA&#xff09;识别语言是否可以被接受…

堆的应用:堆排序和TOP-K问题

上次才讲完堆的相关问题&#xff1a;二叉树顺序结构与堆的概念及性质&#xff08;c语言实现堆 那今天就接着来进行堆的主要两方面的应用&#xff1a;堆排序和TOP-K问题 文章目录 1.堆排序1.1概念、思路及代码1.2改良代码&#xff08;最初建立大堆用AdjustDow&#xff09; 2. TO…

软件体系架构复习二

呃&#xff0c;前面复习的忘了发了。从后面开始吧 Unit 11--18 复习Tips&#xff1a; 重点在于对概念的理解&#xff0c;概念间关系的理解。 对具体的识别方法&#xff0c;处理方法等根据自己的兴趣做一些了解即可 。 如&#xff1a;关于 软件架构脆弱性的成因 &#xff0c; …

企业建设网络安全的几种“降本增效”的思考

文章目录 前言一、基于风险的安全策略,优先保护关键资产二、集中化安全管理三、加强安全意识培训,打造人肉防火墙四、安全自动化运营五、定期更新和打补丁六、安全服务外包七、跟踪关键安全运营指标并展示安全投资回报率八、打造战略情报网络总结前言 在当下的经济寒冬中,网…