当前位置: 首页 > news >正文

MySQL 创建数据库和表全攻略

一、MySQL 创建数据库与表的重要性


MySQL 作为广泛应用的关系型数据库管理系统,创建数据库和表具有至关重要的意义。

在数据存储方面,数据库就如同一个巨大的仓库,为各类数据提供了安全、有序的存储环境。通过创建数据库,可以将相关数据集合在一起,进行统一管理。而表则是数据库中的基本存储单位,它由行和列组成,每行代表一条记录,每列表示记录的某个属性。例如,一个电商数据库中,可以有用户表、商品表、订单表等,分别存储不同类型的数据。

对于数据管理而言,创建合理的数据库和表结构能够提高数据的完整性和一致性。通过设置约束条件,如主键、外键、唯一约束等,可以确保数据的准确性和可靠性。例如,在用户表中,将用户 ID 设置为主键,可以唯一标识每个用户,避免重复数据的出现。同时,外键约束可以建立表与表之间的关系,确保数据的引用完整性。

此外,创建数据库和表还能够提高数据的查询效率。选择合适的数据类型和索引,可以加快数据的检索速度。例如,对于经常用于查询的字段,可以创建索引,以便数据库能够更快地定位到相关数据。

总之,MySQL 中创建数据库和表是数据存储和管理的基础,对于保证数据的安全性、完整性和高效性起着关键作用。

二、创建数据库的方法

(一)使用命令行创建数据库

在 MySQL 中,可以使用命令行来创建数据库。首先,连接到本机上的 MySQL,打开 DOS 窗口,进入目录 mysql\bin,然后键入命令mysql -u root -p,回车后提示输入密码。如果刚安装好 MySQL,超级用户 root 是没有密码的,故直接回车即可进入到 MySQL 中。MySQL 的提示符是:mysql>

要显示当前数据库服务器中的数据库列表,可以输入命令:SHOW DATABASES;。如果要创建数据库,可以使用命令:CREATE DATABASE 数据库名;。例如,创建一个名为test_db的数据库,就输入CREATE DATABASE test_db;

创建数据库后,可以使用命令USE 数据库名;来选择要操作的数据库。比如,使用USE test_db;来选择刚刚创建的test_db数据库。

(二)使用图形界面工具创建数据库

  1. MySQL Workbench
    • 打开 MySQL Workbench,输入密码进入主页面。
    • 点击工具栏处的黄色油桶,此时代码区会出现新的数据库创建页面。
    • 修改数据库名称,点击Apply
    • 会弹出一个弹窗,点击Apply后再点击Finish。主页面左侧数据库区域就有刚才创建的新数据库了。
  2. phpMyAdmin
    • 有两种方法登陆 phpMyAdmin,第一钟是直接点击 wampserver 图标,再点击 phpMyAdmin 即可登陆进来;其次是在浏览器地址中输入http://localhost:8080/phpmyadmin(注意 8080 是端口号,默认的是 80 可不填,简写为http://localhost/phpmyadmin/)。
    • 登陆进来后,点击New,页面的左边会弹出新建数据库:填写数据库名(比如写my_db),排序规则(utf8-general_ci)。
    • 点击创建按钮,在页面的左边就会出现我们刚才创建的数据库了。如果在页面的左边没有找到创建的数据库,则刷新下就会出现了,页面有时候反应较慢。

总之,使用命令行和图形界面工具都可以创建 MySQL 数据库,用户可以根据自己的需求和习惯选择合适的方法。

三、创建表的方法

(一)基本语句示例

在 MySQL 中,使用 CREATE TABLE 语句可以创建表。以下是一个基本的语法示例:

CREATE TABLE table_name (

    column1_name data_type [constraint],

    column2_name data_type [constraint],

   ...

    [table_options]

);

例如,创建一个名为 students 的表,包含 id(整数类型,作为主键)、name(字符串类型,不能为空)和 age(整数类型)列,可以使用以下语句:

CREATE TABLE students (

    id INT NOT NULL AUTO_INCREMENT,

    name VARCHAR(255) NOT NULL,

    age INT,

    PRIMARY KEY (id)

);

在这个例子中,id 列被定义为整数类型,并且设置了 NOT NULL 约束和 AUTO_INCREMENT 属性,这意味着它将自动递增并且不能为空。name 列是长度为 255 的字符串类型,也不能为空。age 列是整数类型。最后,通过 PRIMARY KEY (id) 将 id 列设置为主键,确保表中每条记录的 id 值都是唯一的。

(二)创建带有外键的表

创建带有外键的表可以建立表与表之间的关系,确保数据的引用完整性。例如,假设有一个 courses 表和一个 students 表,我们希望在 enrollments 表中建立学生与课程的关系,并且确保学生和课程的引用是有效的。

首先,创建 courses 表:

CREATE TABLE courses (

    course_id INT NOT NULL AUTO_INCREMENT,

    course_name VARCHAR(255) NOT NULL,

    PRIMARY KEY (course_id)

);

然后,创建 students 表:

CREATE TABLE students (

    student_id INT NOT NULL AUTO_INCREMENT,

    student_name VARCHAR(255) NOT NULL,

    PRIMARY KEY (student_id)

);

最后,创建 enrollments 表,并建立外键约束:

CREATE TABLE enrollments (

    enrollment_id INT NOT NULL AUTO_INCREMENT,

    student_id INT,

    course_id INT,

    PRIMARY KEY (enrollment_id),

    FOREIGN KEY (student_id) REFERENCES students(student_id) ON DELETE CASCADE ON UPDATE RESTRICT,

    FOREIGN KEY (course_id) REFERENCES courses(course_id) ON DELETE CASCADE ON UPDATE RESTRICT

);

enrollments 表中,student_id 和 course_id 列分别作为外键,引用 students 表和 courses 表的主键。通过 ON DELETE CASCADE 和 ON UPDATE RESTRICT 子句,可以定义当父表(students 和 courses 表)中的记录被删除或更新时,外键约束如何影响子表(enrollments 表)中的相关记录。在这个例子中,当 students 表或 courses 表中的记录被删除时,enrollments 表中对应的记录也会被级联删除;当 students 表或 courses 表中的记录被更新时,enrollments 表中的外键引用会被限制更新,以确保引用的有效性。

四、创建数据库和表的步骤

(一)创建数据库步骤

在 MySQL 中,使用 CREATE DATABASE 语句可以创建数据库。语法格式如下:CREATE DATABASE [IF NOT EXISTS][[DEFAULT] CHARACTER SET ] [[DEFAULT] COLLATE ];。其中,数据库名称必须符合操作系统的文件夹命名规则,且在 MySQL 中不区分大小写。

具体操作如下:

  1. 若使用命令行创建数据库,可以在连接到 MySQL 后,输入命令 CREATE DATABASE 数据库名;。例如,创建一个名为 my_database 的数据库,就输入 CREATE DATABASE my_database;
  2. 若使用图形界面工具,如 MySQL Workbench,输入密码进入主页面后,点击工具栏处的黄色油桶,修改数据库名称,点击 Apply,再点击弹窗中的 Apply 和 Finish 即可创建数据库。

检查数据库是否创建成功的方法:

  1. 使用命令行输入 SHOW DATABASES;,如果列出的数据库中包含刚刚创建的数据库名,则说明创建成功。
  2. 也可以使用 SHOW CREATE DATABASE 数据库名; 查看数据库的定义声明,确认数据库的创建情况。例如,使用 SHOW CREATE DATABASE my_database; 可以查看 my_database 的详细信息。

(二)创建表步骤

使用 CREATE TABLE 语句创建表。语法格式如下:CREATE TABLE table_name (column1_name data_type [constraint], column2_name data_type [constraint],... [table_options]);

具体过程如下:

  1. 确定表名和列定义。例如,创建一个名为 employees 的表,包含 id(整数类型,作为主键)、name(字符串类型,不能为空)和 department(字符串类型)列,可以使用以下语句:CREATE TABLE employees (id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, department VARCHAR(255), PRIMARY KEY (id));
  2. 指定数据类型和约束条件。如 id 列设置了 NOT NULL 约束和 AUTO_INCREMENT 属性,确保它不能为空且自动递增;name 列不能为空。

检查表是否创建成功的方法:

  1. 使用 SHOW TABLES; 语句检查表是否在当前数据库中列出。如果列出了刚刚创建的表名,则说明表创建成功。
  2. 也可以使用 DESCRIBE 表名; 或 DESC 表名; 查看表的字段信息,包括字段名、数据类型、是否为主键、是否有默认值等,确认表的结构是否正确。例如,使用 DESCRIBE employees; 可以查看 employees 表的结构信息。

五、创建数据库和表的注意事项

(一)字段设计

  • 字段的原子性:保证每列的原子性,不可分解,意思表达要清楚,不能含糊,高度概括字段的含义。能用一个字段表达清楚的绝不使用第二个字段,必须要使用两个字段表达清楚的绝不能使用一个字段。例如,存储用户的姓名和年龄,应分别使用两个字段,而不是将姓名和年龄合并在一个字段中。
  • 主键设计:主键不要与业务逻辑有所关联,最好是毫无意义的一串独立不重复的数字,常见的比如 UUID 或者将主键设置为 Auto_increment。这样可以避免因业务逻辑的变化导致主键的不稳定。例如,在一个订单系统中,订单号不应该包含与业务相关的特定信息,而应该是一个随机生成的 UUID 或者自动递增的数字。
  • 字段使用次数:对于频繁修改的字段(一般是指状态类字段)最好用独立的数字或者单个字母去表示,不用使用汉字或长字符的英文。这样可以提高数据库的性能,减少数据存储的空间。例如,用数字 1 表示 “已完成” 状态,数字 2 表示 “未完成” 状态,而不是用汉字 “已完成” 和 “未完成”。
  • 字段长度:建表的时候,字段长度尽量要比实际业务的字段大 3 - 5 个字段左右(考虑到合理性和伸缩性),最好是 2 的 n 次方幂值。不能建比实际业务太大的字段长度,因为如果字段长度过大,在进行查询的时候索引在 B - Tree 树上遍历会越耗费时间,从而查询的时间会越久;但是绝对不能建小,否则 MySQL 数据会报错,程序会抛出异常。例如,如果一个存储用户姓名的字段,预计最长的姓名长度为 20 个字符,那么可以将字段长度设置为 32 个字符。

(二)外键与动静分离

  • 外键使用建议:尽量不要建立外键,保证每个表的独立性。如果非得保持一定的关系,最好是通过 id 进行关联,我们使用业务进行管理。虽然外键可以保证数据的完整性和一致性,但是在大数据量的情况下,外键会影响数据库的性能。例如,在一个电商系统中,订单表和商品表之间如果通过外键关联,当订单表中的数据量非常大时,每次插入或更新订单记录都需要检查商品表中的外键约束,这会导致性能下降。
  • 动静分离重要性:最好做好静态表和动态表的分离。静态表存储着一些固定不变的资源,比如城市 / 地区名 / 国家,静态表一定要使用缓存。动态表则是一些频繁修改的表。这样可以提高数据库的性能,减少对静态数据的频繁读取和写入。例如,在一个电商系统中,商品的分类信息可以存储在静态表中,而订单信息可以存储在动态表中。

(三)其他注意事项

  • 关于 code 值:使用数字码或者字母去代替实际的名字,也就是尽量把 name 转换为 code,因为 name 可能会变(万一变化就会查询出多条数据,从而抛出错误),但是 code 一般是不会变化的。另一方面,code 值存储的字符较少,也能减少数据库的存储空间的压力。例如,用数字代码表示商品的类别,而不是用商品类别的名称。
  • 关于 Null 值:尽量不要有 null 值,有 null 值的话,数据库在进行索引的时候查询的时间更久,从而浪费更多的时间。可以在建表的时候设置一个默认值。例如,对于一个存储用户年龄的字段,如果用户没有填写年龄,可以设置默认值为 0。
  • 关于引擎选择:关于引擎的选择,InnoDB 与 MyISAM,MyISAM 的实际查询速度要比 InnoDB 快,因为它不扫描全表,但是 MyISAM 不支持事务,没办法保证数据的 ACID。选择哪个这就要看自己对于效率和数据稳定性方面的实际业务的取舍了。如果业务对数据的完整性和一致性要求较高,应选择 InnoDB 引擎;如果业务对查询速度要求较高,且可以接受一定的数据不一致性,可以选择 MyISAM 引擎。
  • 资源存储:数据库不要存储任何资源文件,比如照片 / 视频 / 网站等,可以用文件路径 / 外链用。这样可以减少数据库的存储压力,提高数据库的性能。例如,对于一个图片存储系统,可以将图片存储在文件系统中,数据库中只存储图片的路径。

相关文章:

MySQL 创建数据库和表全攻略

一、MySQL 创建数据库与表的重要性 MySQL 作为广泛应用的关系型数据库管理系统,创建数据库和表具有至关重要的意义。 在数据存储方面,数据库就如同一个巨大的仓库,为各类数据提供了安全、有序的存储环境。通过创建数据库,可以将相…...

大数据-126 - Flink State 03篇 状态原理和原理剖析:状态存储 Part1

点一下关注吧!!!非常感谢!!持续更新!!! 目前已经更新到了: Hadoop(已更完)HDFS(已更完)MapReduce(已更完&am…...

RFID射频模块(MFRC522 STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 3.工作原理介绍 三、程序设计 main.c文件 MFRC522.h文件 MFRC522.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 RC522 RFID射频模块是一款广泛应用于非接触式RFID系统中的核心组件,由NXP&…...

【JavaSE】--方法的使用

文章目录 1. 方法概念及使用1.1 什么是方法1.2 方法定义1.3 方法调用的执行过程1.4 实参和形参的关系(重要)1.5 没有返回值的方法 2. 方法重载2.1 方法重载概念2.2 方法签名 3. 递归3.1 递归的概念3.2 递归执行过程分析3.3 递归练习 1. 方法概念及使用 1…...

wireshark打开时空白|没有接口,卸载重装可以解决

解决方法:卸载wireshark,全选卸载干净,重新安装旧版的wireshark4.2.7, 甚至cmd下运行net start npf时显示服务名无效,但打开wireshark仍有多个接口 错误描述: 一开始下载的是wireshark的最新版,win11 x64 在安装wir…...

单值二叉树--(C语言)

题目如下: 如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。 只有给定的树是单值二叉树时,才返回 true;否则返回 false。 示例 1: 输入:[1,1,1,1,1,null,1] 输出:true示例 2&a…...

Linux云计算 |【第三阶段】PROJECT1-DAY2

主要内容: 网站架构演变、LNPMariadb数据库分离、Web服务器集群(部署Nginx后端web服务器、部署NFS共享存储服务器、部署Haproxy代理服务器、部署DNS域名解析服务器) 一、网站架构演变: 随着网站访问量和业务复杂度的增加&#x…...

Claude Prompt 汉语新解

感谢刚哥! ;; 作者: 李继刚 ;; 版本: 0.3 ;; 模型: Claude Sonnet ;; 用途: 将一个汉语词汇进行全新角度的解释 ​ ;; 设定如下内容为你的 *System Prompt* (defun 新汉语老师 () "你是年轻人,批判现实,思考深刻,语言风趣" (风格 . ("Oscar Wilde&q…...

【运维监控】influxdb 2.0+grafana 监控java 虚拟机以及方法耗时情况(2)

运维监控系列文章入口:【运维监控】系列文章汇总索引 文章目录 四、grafana集成influxdb监控java 虚拟机以及方法耗时情况1、添加grafana数据源2、添加grafana的dashboard1)、选择新建dashboard方式2)、导入dashboard 3、验证 关于java应用的…...

怎么看待伦敦银交易的风险与收益?

伦敦银交易的风险与收益,在宣传材料中,伦敦银是一种潜在收益很高,潜在风险不大的品种。然而在实践中我们发现,伦敦银交易好像并不如宣传材料说的那样容易做。那么,具体伦敦银交易的风险和收益是怎么样的?那…...

如何通俗易懂的解释TON的智能合约

文章目录 一、小故事一则二、Ton的智能合约在小故事中三、python代码模拟 一、小故事一则 在一个遥远的国度里,有一个被魔法笼罩的小镇,这个小镇每年都会举办一场盛大的戏剧节。这个戏剧节不仅是演员们展示才华的舞台,更是他们交流心得、共同…...

针对Docker容器的可视化管理工具—DockerUI

目录 ⛳️推荐 前言 1. 安装部署DockerUI 2. 安装cpolar内网穿透 3. 配置DockerUI公网访问地址 4. 公网远程访问DockerUI 5. 固定DockerUI公网地址 ⛳️推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下…...

五大注入攻击网络安全类型介绍

1. SQL注入(SQL Injection) SQL注入流程 1.1. 概述 SQL注入是最常见的注入攻击类型之一,攻击者通过在输入字段中插入恶意的SQL代码来改变原本的SQL逻辑或执行额外的SQL语句,来操控数据库执行未授权的操作(如拖库、获取…...

linux-L9.linux中对文件 按照时间排序 显示100 个

find . -type f -exec stat --format %Y %n {} | sort -nr | head -n 100解释: • find . -type f:在当前目录下查找所有文件。 • -exec stat --format ‘%Y %n’ {} :对每个找到的文件执行stat命令,以获取文件的修改时间&#…...

springboot从分层到解耦

注释很详细,直接上代码 三层架构 项目结构 源码: HelloController package com.amoorzheyu.controller;import com.amoorzheyu.pojo.User; import com.amoorzheyu.service.HelloService; import com.amoorzheyu.service.impl.HelloServiceA; import o…...

网络视频流解码显示后花屏问题的分析

问题描述 rtp打包的ps视频流发送到客户端后显示花屏。 数据分析过程 1、用tcpdump抓包 tcpdump -i eth0 -vnn -w rtp.pcap 2、用wireshark提取rtp的payload 保存为record.h264文件 3、用vlc播放器播放 显示花屏 4、提取关键帧 用xxd命令将h264文件转为txt文件 xxd -p…...

MySQL 大量 IN 的查询优化

背景 (1)MySQL 8.0 版本 (2)业务中遇到大量 IN 的查询,例: SELECT id, username, icon FROM users WHERE id IN (123, 523, 1343, ...);其中 id 为主键,IN 的列表长度有 8000 多个 问题 …...

python运维

环境准备 安装python3环境 # centos 安装python3 yum install python3创建激活venv python3 -m venv .venv source .venv/bin/activatezookeeper pip install kazoo 递归复制目录 from kazoo.client import KazooClientdef copy_node(zk, source_path, destination_path)…...

gen_server补充基础学习

学习gen_server的回调结构 gen_server:start_link(Name, Mod, InitArgs, Opts)这个调用是所有事物的起点。它 会创建一个名为Name的通用服务器,回调模块是Mod,Opts则控制通用服务器的行为。在这里可以指定消息记录、函数调试和其他行为。通用服务器通过…...

Python 入门教程(3)基础知识 | 3.1、基础语法

文章目录 一、 基础语法1、缩进规则2、标识符3、多行语句 一、 基础语法 1、缩进规则 学习 Python 与其他语言最大的区别就是,Python 的代码块不使用大括号 {} 来控制类,函数以及其他逻辑判断。python 最具特色的就是用缩进来写模块。缩进的空白数量是可…...

git 合并分支并解决冲突

git 合并分支并解决冲突 切换分支 git checkout <branch-name> 首先切换到要合并的目标分支 合并分支 git merge <source-branch> //将源分支代码合并到当前分支中&#xff0c;源分支的各项新增的提交都会按时间点插入到当前分支的提交记录中 git merge …...

《程序猿之设计模式实战 · 装饰者模式》

&#x1f4e2; 大家好&#xff0c;我是 【战神刘玉栋】&#xff0c;有10多年的研发经验&#xff0c;致力于前后端技术栈的知识沉淀和传播。 &#x1f497; &#x1f33b; CSDN入驻不久&#xff0c;希望大家多多支持&#xff0c;后续会继续提升文章质量&#xff0c;绝不滥竽充数…...

[K8S]Forbidden: pod updates may not change fields other than

背景 在执行kubectl apply -f pod-nginx.yaml的时候报错 The Pod "nginx-test" is invalid: spec: Forbidden: pod updates may not change fields other than `spec.containers[*].image`, `spec.initContainers[*].image`, `spec.activeDeadlineSeconds`, `spec.to…...

C/C++漏洞检测数据集汇总

漏洞检测这个方向最近几年尤为热门&#xff0c;尤其是与深度学习技术相结合的研究&#xff0c;同时一些公开可用的数据集的出现也进一步推动了这些技术的发展。本篇文章总结归纳了目前在 C/C 源代码漏洞检测方向的一些公开数据集以及相关文献。 1 Devign (FFmpegQemu) 简介&am…...

springboot后端开发-常见注解及其用途

文章目录 1. 组件注解2. 依赖注入注解3. 配置类注解4. 测试注解5. 控制器注解6. 安全和认证注解7. 切面相关注解8. API文档相关注解(需引入swagger)9. 其他注解 在Spring Boot框架中&#xff0c;有许多常用的注解用来简化开发过程中的依赖注入、组件扫描、配置、安全控制等方面…...

TypeScript 扩展

扩展 ?:可选参数 可选链事实上并不是TypeScript独有的特性&#xff0c;它是ES11&#xff08;ES2020&#xff09;中增加的特性 可选链使用可选链操作符 ? 作用是当对象的属性不存在时&#xff0c;会短路&#xff0c;直接返回undefined&#xff0c;如果存在&#xff0c;那么…...

按键学院往期视频

按键学院第五期 网游实战系列课程 按键学院第四期 网游实战系列课程01-回合制网游的特点:测试游戏后台按键图色 网游实战系列课程02-神武新手任务的识别与处理:字库识别任务 网游实战系列课程03-神武自动组队与攻击 网游实战系列课程04-神武自动逛地图与攻击 网游实战系列课程0…...

通信工程学习:什么是MRF多媒体资源功能、MRFC多媒体资源功能控制、MRFP多媒体资源功能处理

一、MRF多媒体资源功能 MRF&#xff08;Multimedia Resource Function&#xff0c;多媒体资源功能&#xff09;是3G/IMS网络中定义的提供多媒体资源功能的网络实体&#xff0c;它为3G/IMS网络的业务和承载提供媒体能力支持。MRF通过提供丰富的媒体处理功能&#xff0c;如播放声…...

【Windows】获取进程缓解策略设置情况

目录 一、前言 二、主要概念 三、实现步骤 四、总结 原文出处链接&#xff1a;[https://blog.csdn.net/qq_59075481/article/details/142234952] 一、前言 在现代操作系统中&#xff0c;进程缓解策略&#xff08;Process Mitigation Policy&#xff09;提供了一种防御机制…...

语音识别相关概念

声音如何保存成数字信号&#xff1f; 声音是听觉对声波产生的感知&#xff0c;而声波是一种在时间和振幅上连续的模拟量&#xff0c;本质是介质的振动&#xff0c;&#xff0c;比如空气的振动。那么只需要把这个振动信号记录下来&#xff0c;并用一串数字来表达振动信号振动的…...