mysql创建数据库时怎么将主键设置为UUID,建表语句怎么写

1、打开CMD,输入mysql -uroot -p命令连接mysql,如下图所示 2、通过create创建表,指定ID为varchar(36),并设置为主键,如下图所示 3、在插入数据的时候,调用uuid()函数往主键字段里插入uuid值,如下图所示 4、最后查询插入的数据就可以看到id主键列存放的是uuid类型了,如下图所示 你们的想法是不...
mysql创建数据库时怎么将主键设置为UUID,建表语句怎么写
mysql设置UUID为主键需要先将数据类型设置为VARCHAR(36),然后插入数据的时候用UUID函数插入UUID。下面我用win10系统下的CMD命令行具体演示一下:
1、打开CMD,输入mysql -uroot -p命令连接mysql,如下图所示

2、通过create创建表,指定ID为varchar(36),并设置为主键,如下图所示

3、在插入数据的时候,调用uuid()函数往主键字段里插入uuid值,如下图所示

4、最后查询插入的数据就可以看到id主键列存放的是uuid类型了,如下图所示

2020-01-14
那直接用语句创建就好了,唯一约束可以理解为是主键
create table test
(id int primary key,
name varchar(10),
age int)

说明:其中primary key就是主键,也就代表此表中id字段是唯一的,不可重复。2017-11-11
你们的想法是不是,想在建表时为id指定uuid,然后每次插入数据都会自动为每一条数据生成uuid呢?就像auto_increment主键自增一样呢?
我只想说 you are too young!
我一开始是这样做的:
create table product(
id varchar(36) primary key default uuid()

sql语句报错。
后来查了查资料,发现mysql好像并不支持在建表时,为某一字段指定默认函数值。但是在Oracle数据库中,却支持这样干,也就可以实现插入数据时,自动生成uuid。
所以在mysql中只能在插入数据时,将uuid()函数值赋值给id字段。
后来,我又想了一个方案,我可以去写一个触发器,每次在执行插入操作时,都为id字段更新为uuid(),但是这种方式还是存在很多问题的,这里就不说了。
最后说明一点(uuid适不适合作为主键):
uuid号称“全球唯一”,实际上业务中一般不会只用一个uuid就保证某个字段的唯一性,因为它并不能保证唯一性,uuid的组成:
Mac地址+时间戳+自增序列,前两个都可以修改,自增序列在不同机器本身就无法保证唯一。既然无法保证唯一,那么没有任何处理的情况下直接将uuid作为主键,显然也是不合适的。
2020-04-14
mengvlog 阅读 280 次 更新于 2025-09-10 07:17:38 我来答关注问题0
  • 在MySQL数据库中,可以通过DROP PRIMARY KEY和ADD PRIMARY KEY语句修改主键。示例代码如下:ALTER TABLE `table_name` DROP PRIMARY KEY; //删除主键 ALTER TABLE `table_name` ADD PRIMARY KEY (`id`); //添加主键 注意,修改主键时,需要先删除原有主键,再添加新的主键。四、主键的注意事...

  • 在主服务器上执行SHOW MASTER STATUSG;命令,记录下File和Position的值,这些值将在配置从服务器时使用。配置从服务器:修改从服务器的MySQL配置文件,添加或修改以下参数:serverid=2:设置服务器ID,确保与主服务器的ID不同。replicatedodb=主从同步数据库名称:指定需要同步的数据库名称。重启MySQL服务以...

  • 在MySQL中创建新用户并授权,首先需要通过命令行或MySQL管理工具登录到MySQL服务器。接着,使用GRANT语句来授予新用户特定的权限。例如,若要创建一个新用户并赋予其对特定数据库和表的所有操作权限,可以使用如下命令:grant all privileges on 数据库名.* to '用户名'@'IP' identified by '密码';上述...

  • 进入student数据库后,可以创建表,例如创建一个名为studinfo的表,包含字段(学号,整数类型,主键)和(年龄,整数类型,最大位数2)。通过show table命令,可以查看当前数据库中的所有表,这有助于用户了解数据库结构。如果需要删除student数据库,可以使用drop database student命令。这将永久删除指定的...

  •  深空见闻 win11怎么创建mysql数据库的命令

    在Win11上创建MySQL数据库的命令主要通过MySQL的命令行界面(CLI)来完成。以下是具体步骤和命令:启动MySQL服务:如果MySQL被安装为Windows服务,可以在任务管理器中的“服务”选项卡找到MySQL服务并点击启动。或者在命令提示符(CMD)中运行net start mysql命令来启动MySQL服务。连接MySQL:打开CMD或PowerShell...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部