MySQL入门:数据表的创建

​今天我们来介绍一下除HTML外的另一种语言:MySQL语言;

      MySQL:即一种用于管理和处理关系数据库的标准语言。要用于执行查询、更新、管理数据库中的数据以及定义和操作数据库结构。

接下来我会逐一介绍它的作用以及其中数据表,数据库的相关操作;

其主要功能: 1.查询数据 ( SELECT ): 从一个或多个表中检索数据。2.插入数据 ( INSERT ): 向表中添加新记录。 3.更新数据 ( UPDATE ): 修改现有记录。 4.删除数据 ( DELETE ): 移除记录。 5.定义数据库结构 ( CREATE , ALTER , DROP ): 创建、修改或删除数据库对象(如表、索引等)。

数据库相关操作:

创建数据库了:

       创建数据库是通过SQL语句来完成的,通常使用 create database 语句。 一旦创建了数据库,
就可以在其上定义表和其他数据库对象。
SQL语句:

create database bookstore

 释义:这条语句意为创建了一个名为 bookstore 的数据库。

删除数据库:

        删除数据是通过SQL语句来完成的,通过使用drop database语句来进行的。删除数据库会永久删除数据库及其所有内容,因此在执行此操作前请谨慎考虑。

SQL语句:

 drop database bookstore

 释义:这条语句删除了名为 bookstore 的数据库。

数据库表:

       数据库表是用来存储数据的二维表格,每一行称为一条记录(或元组),每一列表示一个属性(或字段)。 表中的每一行记录代表一个对象的状态,而每一列表示对象的一个属性。 在面向对象编程中,对象是类的实例,具有状态和行为。 在数据库设计中,表可以看作是对类的实例化,每条记录就是一个对象,而每一列表示对象的属性。

author 作者表:

 注:在这个表格中,id 是主键,name 是作者的名字,bio 是作者的简介。

图解如下:

book 书籍表:

注:在这个表格中,id 是主键,title 是书籍的标题,publication_date 是书籍的出版日期。

数据类型:

       介绍数据类型定义了可以存储在字段中的数据种类。选择合适的数据类型对于保证数据完整性和提高性能至关重要。

       常用数据类型: 整型 ( int ) :用于存储整数。 浮点型 ( double ) :用于存储带有小数的数值。 字符型 ( varchar ) :用于存储文本字符串。 日期时间型 ( date ) :用于存储日期。

创建表:

介绍:创建表是通过SQL语句来完成的,通常使用 create table 语句。创建表时可以定义表中的各个字段及其数据类型。

SQL语句:
create table student (
id int,
name varchar(100),
age int
);

显示:

表的约束:
介绍:主键约束用于唯一标识表中的每一条记录。每张表都应该具备一个主键。 作用是 确保字段值的唯一性。数据不可重复。
SQL语句:
create table student (
id int primary key,
name varchar(100),
age int
);

注:主键约束(primary key)确保了表中的每一条记录都是唯一的,这有助于后续的操作,例如查询、更新或删除单条记录。

非空约束 (not null)

介绍:非空约束确保字段值不能为空。 作用是 防止数据丢失或错误。
SQL 语句
create table student (
id int primary key,
name varchar(100) not null,
age int
);

:非空约束确保了某些关键字段(如姓名)必须有值,这样可以避免数据的不完整性。

唯一约束 ( unique )
介绍:唯一约束确保字段或字段组合的值在表中是唯一的。 作用是 避免重复数据
SQL语句:
create table student (
id int primary key,
name varchar(100) not null,
email varchar(255) unique
);
默认值约束 ( default )
介绍默认值约束为字段提供默认值,在插入新记录时不指定值时自动使用。 作用是 简化数据输入。
SQL语句:
create table student (
id int primary key,
name varchar(100) not null,
age int default 18
);

:默认值约束可以在插入记录时如果没有指定某些字段的值时,默认使用设定的值,从而简化数据输入过程。

检查约束 ( check )
介绍:检查约束确保字段值满足特定条件。 作用是 防止无效数据的插入。比如年龄大于18小于65,若不符合则显示错误。

SQL语句:

create table student (
id int primary key,
name varchar(100) not null,
age int check (age >17 and age < 66)
);

 字符释义:and:表并且;or:表或者;

 :检查约束确保了年龄字段的值在合理的范围内,这样可以避免无效的数据插入。

自增字段 ( auto_increment )
介绍自增字段在每次插入新记录时自动增加,通常用于主键字段。 作用是 简化主键的管理、

SQL语句:

create table student (
id int auto_increment primary key,
name varchar(100) not null,
age int
);

注:自增字段确保了每次插入新记录时,主键字段自动递增,每次加一,不需要手动指定。这样可以简化主键的管理。

完整案例展示:

展示:创建一个含多种约束式学生表,并使用所有在以上提到过的约束类型。

create table students (
id int auto_increment primary key,
name varchar(100) not null,
phone_number varchar(20) unique,
age int default 18 check (age = 0 and age = 150)
);

 展示:

释义:I.id 字段作为自增主键,确保每条记录都是唯一的,并且每次插入新记录时自动递增。II.name 字段不允许为空,确保每条记录都有姓名信息。 III.phone_number 字段设置了唯一约束,确保手机号码在学生表中是唯一的。 VI.age 字段设置了默认值为18,并通过 check 约束确保年龄的有效范围。

总结:希望本篇有关于MySQL创建数据表和数据库的知识点内容能对你带来一定的帮助,同时非常感谢各位大佬们的点赞与支持,咱们下一篇不见不散。

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

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

相关文章

[图论]生成树 引言

生成树 引言 生成树&#xff1a;一个连通图的生成树是该图的一个极小连通子图。生成树中含有图中全部(设 V V V个)顶点及构成一棵树的 V − 1 V-1 V−1条边&#xff0c;且生成树中不应有环。最小生成树(MST)&#xff1a;图的所有生成树中&#xff0c;边权之和最小的生成树。显…

AI调试工具有哪些?

一、深度学习框架专用调试工具 TensorBoard • 功能&#xff1a;实时监控训练指标&#xff08;损失值、准确率&#xff09;、可视化神经网络结构、分析参数分布和梯度信息 • 适用框架&#xff1a;TensorFlow、PyTorch&#xff08;通过插件&#xff09; • 特点&#xff1a;支持…

深入理解 MCP 协议:开启 AI 交互新时代

深入理解 MCP 协议&#xff1a;开启 AI 交互新时代&#x1f680; 在当今人工智能蓬勃发展的时代&#x1f310;&#xff0c;大型语言模型&#xff08;LLM&#xff09;已经在众多领域展现出了强大的能力&#xff0c;令人惊叹&#x1f44f;&#xff01;然而&#xff0c;传统的 LLM…

微信、抖音、小红书emoji符号大全

1、Emoji 日常符号 &#x1f463;&#x1f440;&#x1f441;️&#x1f444;&#x1f48b;&#x1f442;&#x1f9bb;&#x1f443;&#x1f445;&#x1f9e0;&#x1fac0;&#x1fac1;&#x1f9b7;&#x1f9b4;&#x1f4aa;&#x1f9be;&#x1f9bf;&#x1f9b5;&a…

【嵌入式】——Linux系统远程操作和程序编译

目录 一、虚拟机配置网络设置 二、使用PuTTY登录新建的账户 1、在ubuntu下开启ssh服务 2、使用PuTTY连接 三、树莓派实现远程登录 四、树莓派使用VNC viewer登录 五、Linux使用talk聊天程序 1、使用linux自带的talk命令 2、使用c语言编写一个talk程序 一、虚拟机配置网络…

春和景明-C语言简单代码

题目要求&#xff1a; 请在centOS Linux中编写一个C语言程序实现如下功能&#xff1a; 同时创建100个用户&#xff0c;用户的账户名称为&#xff1a;Student01 Student02 … Student100;设置每个用户的初始密码为&#xff1a;stud123456请用gcc编译C的源代码&#xff0c;生…

设计模式之工厂模式(factory pattern):在商品对象创建系统中的应用

目录 一、设计思路 1. 简单工厂模式 2. 工厂方法模式 3. 抽象工厂模式 二、UML类图&#xff08;PlantUML格式&#xff09; 1.简单工厂模式 2.工厂方法模式 3.抽象工厂模式 三、实现过程与结果 1. 简单工厂模式 2. 工厂方法模式 3. 抽象工厂模式 四、总结 在面向对…

Trae,字节跳动推出的 AI 编程助手插件

Trae 插件是 Trae 旗下全新一代的人工智能编程助手&#xff08;前身为 MarsCode 编程助手&#xff09;&#xff0c;以插件形式集成在本地开发环境中&#xff0c;具备极高的兼容性和灵活性&#xff0c;旨在提升开发效率和代码质量。它支持超过100种编程语言&#xff0c;兼容主流…

工作纪实_63-Mac电脑使用brew安装软件

最近在接触kafka&#xff0c;想着在自己的电脑安装一套环境&#xff0c;docker也能行&#xff0c;但是还是想装一些原生的软件试试看&#xff0c;因此便想着整理一下brew的命令&#xff0c;这命令确实是方便&#xff0c;不需要下载tar包乱八七糟的东西&#xff0c;一键安装 bre…

Python语法系列博客 · 第8期[特殊字符] Lambda函数与高阶函数:函数式编程初体验

上一期小练习解答&#xff08;第7期回顾&#xff09; ✅ 练习1&#xff1a;找出1~100中能被3或5整除的数 result [x for x in range(1, 101) if x % 3 0 or x % 5 0]✅ 练习2&#xff1a;生成字符串长度字典 words ["apple", "banana", "grape…

Redis--主从复制

目录 一、配置 1.1 建立复制 1.2 断开复制 1.3 安全性 1.4 只读 1.5 传输延迟 二、拓扑 2.1 一主一从结构 2.2 一主多从结构 2.3 树形主从结构 在分布式系统中为了解决单点问题&#xff0c;通常会把数据复制多个副本部署到其他服务器&#xff0c;满足故障恢 复和负载均衡等需求…

已注册商标如何防止被不使用撤销!

近年来已注册商标被撤销越来越多&#xff0c;不乏著名企业或机构&#xff0c;普推知产商标老杨看到前一阵看到央视和百度等申请的商标也被申请撤销&#xff0c;连续三年不使用撤销也是正常的商标流程。 已注册商标被撤销普推老杨看到案例主要是集中在一些早期申请注册的好记的商…

解密大模型背后的秘密:训练、优化与挑战

解密大模型背后的秘密&#xff1a;训练、优化与挑战 在当今的人工智能领域&#xff0c;大模型&#xff08;Large Language Models, LLMs&#xff09;已经成为了一个不可忽视的存在。从自然语言处理到图像生成&#xff0c;再到推荐系统&#xff0c;大模型以其强大的泛化能力和创…

App自动化测试流程方案与架构设计

App自动化测试流程方案与架构设计 一、核心流程设计 #mermaid-svg-kN4GmIvHb8MMT83M {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-kN4GmIvHb8MMT83M .error-icon{fill:#552222;}#mermaid-svg-kN4GmIvHb8MMT83M .e…

字节跳动发布视频生成基础大模型 Seaweed-7B

近日&#xff0c;字节跳动发布了其全新视频生成基础大模型 Seaweed-7B&#xff0c;该模型由字节 Seed 团队开发&#xff0c;参数量仅为 70 亿&#xff0c;在多个方面展现出卓越性能&#xff0c;为 AI 视频生成领域带来了新的突破。 功能特点 支持多种生成方式&#xff1a;Sea…

如何基于区块链进行虚拟电厂运营平台建设?

本项目旨在基于区块链技术建设虚拟电厂运营平台&#xff0c;以提升省内大用户及工业企业和工业园区的需求响应能力&#xff0c;优化能源结构配置&#xff0c;并推动能源交易、需求响应和现货交易等新型业态的发展。通过建设虚拟电厂&#xff0c;项目将实现工业企业及园区各供用…

LeetCode[459]重复的子字符串(KMP解法)

思路&#xff1a; 最近迷上了KMP算法&#xff0c;所以这道题也是来搞一下KMP算法&#xff0c;总所周知KMP是需要维护一个前缀表&#xff0c;KMP算法不是比较一个字符串包不包含另一个字符串的吗&#xff0c;这个重复字符串的题也能用&#xff1f;猫爷&#xff1a;毋庸置疑&…

spring-batch批处理框架(2)

文章目录 八、作业控制8.1 作业启动8.1.1 SpringBoot 启动8.1.2 Spring 单元测试启动8.1.3 RESTful API 启动 8.2 作业停止方案1&#xff1a;Step 步骤监听器方式方案2&#xff1a;StepExecution停止标记 8.3 作业重启8.3.1 禁止重启8.3.2 限制重启次数8.3.3 无限重启 九、Item…

uniapp的通用页面及组件基本封装

1.基本布局页面 适用于自定义Navbar头部 <template><view :style"{ background : param.bgColor , height: 100% }"><block v-if"param.noHead"><slot name"head"></slot></block><block v-if"!p…

基于MTF的1D-2D-CNN-GRU-Attention时序图像多模态融合的故障识别,适合研究学习(Matlab完整源码和数据),附模型研究报告

基于MTF的1D-2D-CNN-GRU-Attention时序图像多模态融合的故障识别&#xff0c;适合研究学习&#xff08;Matlab完整源码和数据&#xff09;&#xff0c;附模型研究报告 目录 基于MTF的1D-2D-CNN-GRU-Attention时序图像多模态融合的故障识别&#xff0c;适合研究学习&#xff08;…