MySQL 创建数据库和表全攻略

news2024/12/27 10:54:26

一、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 引擎。
  • 资源存储:数据库不要存储任何资源文件,比如照片 / 视频 / 网站等,可以用文件路径 / 外链用。这样可以减少数据库的存储压力,提高数据库的性能。例如,对于一个图片存储系统,可以将图片存储在文件系统中,数据库中只存储图片的路径。

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

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

相关文章

计算机毕业设计体育资讯个性化推荐网站网站内容留言评论前台注册后台管理/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序

一、网站内容 ‌个性化推荐‌:根据用户浏览历史和兴趣,推送相关体育资讯。‌丰富资讯‌:包含体育赛事直播、新闻报道、专栏评论等。 二、留言评论系统 ‌用户互动‌:允许用户对资讯进行留言和评论,增强社区互动性。…

python基础知识 (五)--容器、索引、切片、字符串的遍历、查找、修改元素

目录 容器 容器大总结 索引 切片 字符串的遍历 for循环语法: while循环语法: 查找元素 修改元素 例题 1.验证码 2.抽取大红包 3.a和b互换位置 容器 在Python中,常见容器有: (1)字符串&#x…

k8s的加密配置secret和应用配置configmap

目录 加密配置 secret的三种类型 创建opaque类型的两种方式 方法一 方法二 如何把secret挂载到pod当中 把secret作为环境变量传到pod当中 指定harbor私有仓库加密的secret配置 应用配置 configmap 创建configmap的方式 在pod里面用configmap做pod的环境变量 **用c…

[Linux入门]---使用exec函数实现简易shell

文章目录 1.简易实现2.人机交互,获取命令行3.命令行分割4.执行命令5.内建命令6.myshell代码 1.简易实现 2.人机交互,获取命令行 代码如下: int quit0; #define LEFT "[" #define RIGHT "]" #define LABLE "#&quo…

如何免费试用OpenAI o1 preview大模型

OpenAI于 2024 年 9 月 12 日推出 o1(以前称为 Strawberry 项目) 。这一系列新推理模型旨在更有效地解决复杂问题。ChatGPT Plus 和 Team 用户可以访问 o1-preview 和 o1-mini,但消息量有限。 OpenAI o1-preview与 GPT-o对比 o1-previewGPT…

Excel 基础知识-操作手册2

十、查找与引用函数 Excel中的查找与引用函数非常丰富,以下是一些主要的函数及其使用示例: 1. **VLOOKUP** - 语法:VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup]) - 示例:假设A列是员工编号,B…

27 顺序表 · 链表

目录 一、单链表 (一)概念 1、节点 2、链表的性质 (二)单链表的实现 (三)单链表算法题 1、移除链表元素 2、反转链表 3、链表的中间节点 4、合并两个有序的单链表 5、链表分割 6、链表的回文结构…

pdf怎么加页码?5种pdf添加页码指南分享,快来领取!

如何在一个包含大量页面的大型pdf文件中快速找到特定的页面或信息呢?最简便的方法就是为pdf添加页码。pdf添加页码能够清晰显示页面顺序,帮助读者轻松浏览大型pdf文档,同时也便于寻找特定章节和确定整体长度。然而,并非所有pdf文件…

VirtualBox Install MacOS

环境搭建 git clone https://github.com/myspaghetti/macos-virtualbox 脚本配置 修改macos-guest-virtualbox.sh部分内容为 vm_name"macOS" # name of the VirtualBox virtual machine macOS_release_name"Catalina" # install &quo…

PHP 环境搭建教程

搭建一个稳定的PHP开发环境是开发Web应用的基础。在Linux系统上,LAMP(Linux, Apache, MySQL/MariaDB, PHP)堆栈是最广泛使用的组合。本文将详细介绍如何在Linux上搭建PHP开发环境,涵盖安装步骤、配置和测试。更多内容,…

Docker操作MySQL

1,拷贝; docker cp mysql01:/etc/mysql .2,修改conf.d和mysql.conf.d文件 3, vim mysql/my.cnf 4,拷贝并替换my.cnf文件 5,mysql镜像重启命令: docker exec -it mysql01 -uroot -p0000006&…

LOAM学习

LOAM Ceres Solver 中的LocalParameterization理解ALOAM雷达里程计主要步骤论文A-LOAM laser Odometry代码LiDAR Odometry寻找角点特征代码流程分析寻找面点特征 求解器设置 Ceres Solver 中的LocalParameterization理解 该LocalParameterization类用来解决非线性优化中的过参…

最全的软件测试面试题(含答案)

软件的生命周期(prdctrm) 计划阶段(planning)-〉需求分析(requirement)-〉设计阶段(design)-〉编码(coding)->测试(testing)->运行与维护(running maintrnacne) 测试用例 用例编号  测试项目  测试标题  重要级别  预置条件  输入数据  执行步骤   预期结果 1…

python做游戏好用吗

Python做游戏是完全可以的,而且也非常简单,有一个专门针对游戏开发的平台(模块)—pygame,允许开发人员快速设计游戏而又摆脱了低级语言的束缚,下面我简单介绍一下这个模块的安装和使用: 1、首先…

Java手写RPC框架-01-开篇

项目背景 随着业务不断升级,系统规模不断扩大, 单体架构会产生越来越多的问题,需要引入微服务将原先架构解耦为一个个模块。每个服务模块放在不同的服务器上,能够保证系统在高并发环境下的正常运转。 各个服务模块之间如何相互调…

想了解医疗大模型吗?请看《智能系统学报》实验室最新综述论文

本文改编自实验室的最新综述论文《医疗领域的大型语言模型综述》,该论文发表于《智能系统学报》。《智能系统学报》是中国人工智能学会会刊、“中国人工智能学会推荐中文学术期刊”列表中的A类期刊。该论文合作单位包括上海理工大学、上海儿童医学中心、复旦大学附属…

LangChain-Chatchat本地搭建部署

文章目录 前言一、安装部署1.软硬件要求2. 安装 Langchain-Chatchat3.安装Xinference4.遇到的问题问题1:Failed building wheel for llama-cpp-python问题2:Failed building wheel for pynini问题3:运行xinference错误 二、初始化项目配置并运…

了解软件测试的概念

本文我们来了解软件测试 的一些基本概念。同时需要记住衡量软件测试结果的依据—需求; 1. 需求的概念 满足用户期望或正式规定文档(合同、标准、规范)所具有的条件和权能,包含用户需求和软件需求。(其实就是客户想要软…

摩尔信使MThings逻辑控制实例——交通灯

摩尔信使MThings提供了强大的数据配置和逻辑控制功能,可为用户带来一种高效且直观的方式进行管理和控制交通灯系统。与传统的PLC(可编程逻辑控制器)相比,MThings的界面更加用户友好,使得即使是非专业的用户也能够轻松地…

在 Mac 中设置环境变量

目录 什么是环境变量,为什么它们重要?什么是环境变量?举个例子 如何查看环境变量如何设置和修改环境变量1. 临时设置环境变量2. 永久设置环境变量3. 修改现有环境变量 环境变量在开发中的应用在 Node.js 项目中使用环境变量在 Python 项目中使…