mysql联查sql语句
sql语句:增删改查,其中 增、删、改只用于单表多表级联删除,级联更新有时候会出现(例如:删除父类别,子类别也会被删除)多表查询:多表联查、子查询建表语句: 一般不需要语句建表,语句了解认识即可,手动...
2024.11.15由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能。
1、创建sequence表CREATE TABLE `sequence` (`name` VARCHAR ( 50 ) COLLATE utf8_bin NOT NULL COMMENT ‘序列的名字‘,`current_value` INT ( 11 ) NOT NULL COMMENT ‘序列的当前值‘,`increment` INT ( 11 ) NOT NULL DEFAULT ‘1‘ COMMENT ‘序列的自增值‘,PRIMARY KEY ( `name` ) ) ENGINE = INNODB DEFAULT CHARSET = utf8 COLLATE = utf8_bin;2、创建–取当前值的函数drop FUNCTION IF EXISTS currval; delimiter $ CREATE FUNCTION currval (seq_name VARCHAR(50)) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT ‘‘ BEGIN declare value INTEGER; SET value = 0; select current_value INTO value FROM sequence WHERE name = seq_name; RETURN value; END$ delimiter ; 3、创建–取下一个值的函数drop FUNCTION IF EXISTS nextval; delimiter $ CREATE FUNCTION nextval (seq_name VARCHAR(50)) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT ‘‘ BEGIN update sequence SET current_value = current_value + increment WHERE name = seq_name; RETURN currval(seq_name); END $ delimiter ; 4、创建–更新当前值的函数drop FUNCTION IF EXISTS setval; delimiter $ CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT ‘‘ BEGIN update sequence SET current_value = value WHERE name = seq_name; RETURN currval(seq_name); END $ delimiter ; 5、测试insert INTO sequence VALUES (‘hwb_Seq‘, 0, 1);--添加一个sequence名称和初始值,以及自增幅度select SETVAL(‘hwb_Seq‘, 10);--设置指定sequence的初始值select CURRVAL(‘hwb_Seq‘);--查询指定sequence的当前值select NEXTVAL(‘hwb_Seq‘);--查询指定sequence的下一个值这里,hwb_Seq可以认为是一个表名,通过insert语句插入指定表的第一个序列,然后使用NEXTVAL方法,不断更新这一列数据,来获取下一个序列的值。可以通过这张表,来实现N张表的自增序列的统一管理。
觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~
sql语句:增删改查,其中 增、删、改只用于单表多表级联删除,级联更新有时候会出现(例如:删除父类别,子类别也会被删除)多表查询:多表联查、子查询建表语句: 一般不需要语句建表,语句了解认识即可,手动...
2024.11.15概览最近开始在学习mysql相关知识,自己根据学到的知识点,根据自己的理解整理分享出来,本篇文章会分析下一个sql语句在mysql中的执行流程,包括sql的查询在mysql内部会怎么流转,sql语句的...
2024.11.15一、向MyServer数据库里的5张表添加约束:1、向部门表Department添加约束字段名数据类型表关系备注D_IdINT主键 自动增长 NOT NULL部门IDD_NameVarchar(10)...
2024.11.15使用 drop 语句,可以删除索引、表和数据库。drop INDEX 语句我们可以使用 drop INDEX 命令删除表的索引。不同的数据库其具体应用略有区别,如下MySQL 的drop INDEX ...
2024.11.15创建学生表create table t_student(id intauto_increment primary key ,city_no varchar(30),city_name varchar(...
2024.11.13