news 2026/4/18 8:21:08

数据库如何建表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据库如何建表

文章目录

  • 1 创建并使用数据库
    • 1.1 打开命令行
    • 1.2 运行MySQL
    • 1.3 建立数据库以及表数据
  • 2 创建表时约束条件
    • 2.1 约束类型
    • 2.2 其他SQL语句

1 创建并使用数据库

1.1 打开命令行

有的是直接输入密码就可以(软件版比较常用)。

有的是首先Win+r,输入cmd,打开MySQL命令行(用的多一些)。

还有的是到数据库安装目录下的bin文件夹,在地址栏中运行cmd。

注意,Windows启动 MySQL 的几种方式:http://u3v.cn/6j2iwa。

1.2 运行MySQL

运行cmd后输入:mysql -u root -p再回车,我的没有密码,所以password那里没有输入。

正常来讲输入自己设置的密码:(默认:123456)直接回车。

1.3 建立数据库以及表数据

首先就是建立一个数据库,在这里我们把数据库的名字命名为:jdbc_demo,输入:

createdatabasejdbc_demo;

然后我们检查一下是否创建成功,输入:

showdatabases;

使用数据库,输入:

usejdbc_demo;

创建表,让表中有ID、名字、密码三条信息(里面信息可以随便改),输入:

create tableuser(idint(4)notnullprimary key auto_increment,usernamevarchar(20)notnull,passwordvarchar(10)notnull);

当然我们在创建表之前可以先判断一下这个表在不在;

如果数据库中存在这个表,就把它从数据库中drop掉。

DROPTABLEIFEXISTS表名;

总的来说可以这样写:

IF EXISTS表名;作用:如果表存在就删掉(这段代码怎么执行都不会报错)。

DROPTABLEIFEXISTSuser;-- IF EXISTS 表名; 作用:如果表存在就删掉(这段代码怎么执行都不会报错)createtableuser(idint(4)primarykeyauto_increment,-- 主键ID 可以不设置非空,因为主键本来就是非空且唯一usernamevarchar(20)notnull,-- 用户名 非空passwordvarchar(10)notnull-- 密码 非空);

查看表是否存在,输入:

showtables;

查看表的定义,输入:

descuser;

插入数据(我们在这里随便写一下),输入:

insert into uservalues(0,"tom","12");

查看数据,输入:

select*fromuser;

到这里我们就完成一个创建数据库、建表的过程了,我们看一下运行效果:

注意事项:所有的符号都是英文编写。

2 创建表时约束条件

约束是建表时给某一列增加的强制数据规则;

创建表的语法结构:

CREATETABLE<表名>(<列名><数据类型>[列级完整性约束定义]{,<列名><数据类型>[列级完整性约束定义]}[,表级完整性约束定义]);

2.1 约束类型

根据上表student表结构写一下约束类型:

  • 主键PRIMARY KEY(一个表最多只能设置一个,是表每行的唯一性标识,非空且唯一);
  • 外键:FOREIGN KEY(是别的表中的主键,两个表有依赖关系),被别的表依赖的表称为父表,依赖别的表的表成为子表,子表数据增加或修改时,数据必须在父表中存在。父表中数据删除或修改时,数据没有被子表使用;
  • 非空NOT NULL(不允许为空);
  • 唯一性UNIQUE KEY(如果某列定义加了这个约束,那后续数据不允许出现重复,唯一约束允许NULL值的存在),比如说手机号。每个表最好都有主键约束;
  • 检查约束CHECK(条件表达式),用于限制列的取值范围或规则,例如限制性别只能是男或女;
  • 自增auto_increment(常用在主键上,如果ID有1、2、3、4、5,删掉了3号,那么会变成:1、2、4、5);

【例一】用student表进行举例;

snonamesexagedepuid
09512101张三18计算机系000001
09512102李四19计算机系000002
09512103王五20计算机系000003
列名数据类型约束说明
snoCHAR(8)主键每个学生学号应非空且唯一
nameCHAR(10)非空姓名信息必须要保存
sexCHAR(2)检查取值“男”或“女”
ageINT检查小于10,大于60的学生年龄无意义
depVARCHAR(26)default默认值为“计算机系”
uidCHAR(18)唯一值每个人的身份证号是唯一

创建student表;

CREATETABLEstudent(snoCHAR(8)PRIMARYKEY,nameCHAR(10)NOTNULL,sexCHAR(2)CHECK(sex='男'ORsex='女'),ageINTCHECK(age>=10ANDage<=60),depVARCHAR(26)default'计算机系',uidCHAR(18)UNIQUE);

【例二】用stulesson表进行举例

snocnamescore
001数据库原理90
003数据库原理80
003C语言75
列表数据类型约束说明
snoCHAR(8)
cnameCHAR(50)非空姓名信息必须要保存
scoreINT检查在0~100之间

创建stulesson

CREATETABLEstulesson(snoCHAR(8),cnameCHAR(50)NOTNULL,scoreINTCHECK(score>=0ANDscore<=100),PRIMARYKEY(sno,cname),FOREIGNKEY(sno)REFERENCESstudent(sno))

注释:

  • <表名>:所要定义的基本表的名字
  • <列名>:组成该表的各个属性(列)
  • <列级完整性约束条件>:涉及相应属性列的完整性约束条件
  • <表级完整性约束条件>:涉及一个或多个属性列的完整性约束条件

其中PRIMARY KEY为主码约束,CHECK为检查约束。

2.2 其他SQL语句

删除数据库drop database数据库名;

删除表drop table表名;

在表的末尾添加一个列Alter table表名add列名 数据类型 (约束条件);

在表的开头添加一个列Alter table表名add列名 数据类型 (约束条件)first

此外:想直接导入sql文件或者写好后想导出数据库怎么办,可以参考下面这篇文章:http://i9n.cn/EzpXi。

3 char 和 varchar 区别

charvarchar都是SQL数据库中用于存储字符串数据类型的字段类型,它们的主要区别在于存储方式空间效率以及长度处理

(1)存储方式

  • char:定长字符串类型,每个char类型的字段会占用预定义的固定长度的空间,不论实际存储的字符串长度是否达到预设长度。例如,如果你声明一个char(10)字段,那么即使你只存储了3个字符,也会占用10个字符的存储空间,并用空格或其他空白字符填充剩余的7个字符位置。
  • varchar:变长字符串类型,根据实际存储的字符数动态分配存储空间。例如,对于varchar(10),若存储3个字符,只会占用包含3个字符及必要结束标记的存储空间。

(2)空间效率

  • char:当数据长度往往固定且较小,或者经常填充到预定义长度时,空间利用率较高,但存储短字符串时可能会造成空间浪费。
  • varchar:更适合存储长度变化较大的字符串,能有效节省空间,特别是对于大多数字符串都不满预定义长度的情况下。

(3)性能

  • char:因为长度固定,在数据存储和检索上可能会更快,特别是在索引密集型操作中,因为存储结构更加紧凑和可预测。
  • varchar:数据长度不固定,尽管现代数据库系统对此做了优化,但在某些条件下,尤其是在索引较大且字符串长度变化范围大的情况下,其性能可能略低于char。

(4)适用场景

  • char:适用于存储固定长度的数据,如身份证号码、ID、邮政编码等,或者是长度一定且不需要额外空间的场景。
  • varchar:适用于存储长度可变的数据,如姓名、地址、评论等,这些数据长度可能有很大差异。

需要注意的是,不同数据库系统对charvarchar的具体实现可能会有所不同,包括最大长度限制、是否填充空格、存储效率等方面。在MySQL等数据库中,varchar的最大长度可达65535字节,而在Oracle数据库中,varchar2varchar的增强版本,通常用于替代varchar

文章已获作者授权转载,版权归原作者所有,如有侵权,与本账号无关,可联系删除。 原文作者:二哈喇子!
原文链接:https://rej177.blog.csdn.net/article/details/122727753?spm=1001.2014.3001.5502

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 4:03:10

FBM242-P0916JZ继电器离散输出模块

FBM242-P0916JZ 是 Foxboro I/A Series 分布式控制系统中的继电器离散输出模块&#xff0c;主要用于将控制系统的数字指令转换为继电器开关动作&#xff0c;从而驱动现场各类执行设备。模块功能与特点说明如下&#xff1a;FBM242 为离散输出功能模块&#xff0c;用于开关量控制…

作者头像 李华
网站建设 2026/4/18 4:05:01

620-0048数据收集模块

620‑0048 数据收集模块 简介620‑0048 是 Honeywell 控制系统中的一种数据收集模块&#xff0c;属于工业自动化模块的一种&#xff0c;用于实时采集、汇总和传输系统运行数据。主要用途与功能&#xff1a;作为自动化控制系统中的数据采集单元&#xff0c;负责从多个设备或传感…

作者头像 李华
网站建设 2026/4/15 18:12:11

基于51/STM32单片机智能家居温控风扇PWM调速人体感应声控APP设计(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于51/STM32单片机智能家居温控风扇PWM调速人体感应声控APP设计(设计源文件万字报告讲解)&#xff08;支持资料、图片参考_相关定制&#xff09;_文章底部可以扫码 STM32-S304-温湿度风扇PWM调速10档人体感应手动自动OLED屏声光提醒(无线方式选择)产品功能描述&#xff1a; 本…

作者头像 李华
网站建设 2026/4/18 3:36:02

技术实战:用 Python 脚本高效采集与分析手机操作日志

在移动端开发、测试或问题排查场景中&#xff0c;手机操作日志&#xff08;如按键、触控、应用切换、系统事件&#xff09;是定位问题、分析用户行为的核心数据。手动导出日志不仅效率低&#xff0c;还难以实现定制化筛选与实时分析。本文从技术视角&#xff0c;拆解如何基于 P…

作者头像 李华
网站建设 2026/4/18 3:37:26

unet image Face Fusion融合模式怎么选?normal/blend/overlay详解

unet image Face Fusion融合模式怎么选&#xff1f;normal/blend/overlay详解 1. 为什么融合模式的选择比你想象中更重要 很多人第一次用 unet image Face Fusion 时&#xff0c;会直接拖动融合比例滑块、点下“开始融合”&#xff0c;然后盯着结果等几秒——但很快发现&…

作者头像 李华