重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

mysql怎么创建序列,数据库如何创建序列

关于mysql 创建序列

mysql下序列是用关键字auto_crement,起始值及步长增长值由系统以下参数确定:

成都创新互联公司业务包括:成品网站、企业产品展示型网站建设、成都品牌网站建设、电子商务型网站建设、外贸网站建设(多语言)、商城网站开发、按需设计网站、全网整合营销推广等。效率优先,品质保证,用心服务是我们的核心价值观,我们将继续以良好的信誉为基础,秉承稳固与发展、求实与创新的精神,为客户提供更全面、更优质的互联网服务!

mysql show variables like '%auto_increment%';

+--------------------------+-------+

| Variable_name | Value |

+--------------------------+-------+

| auto_increment_increment | 1 |

| auto_increment_offset | 1 |

+--------------------------+-------+

2 rows in set (0.00 sec)

mysql

其中auto_increment_offset表示起始值(且必须由1开始),参数表示auto_increment_increment表示步长增长值(只能是正整数)。

建表示例:

create table t111

(id int auto_increment primary key,

remark varchar(50)

);

由上面所说可知,你的需求在mysql下单用auto_crement是实现不了的。建议你考虑别的办法吧,或由一些变通的方式实现。

mysql如何创建一个序列

序列只有db2

oracle有,mysql没有序列的,不过你可以给你所所创建的表的主键设置为自增。

例如

create

table

A

(

id

int(20)

auto_increment

)

不过设置为自增的键必须是数值类型的。

MySQL 序列使用

使用函数创建自增序列管理表(批量使用自增表,设置初始值,自增幅度)

MySql的有序列吗?怎么创建序列,并每次增长1

也不给分!在你id后面加上 auto_increment ,之后你的id就会自动增长了

MySQL实现类似Oracle序列的方案

MySQL实现类似Oracle的序列

Oracle一般使用序列(Sequence)来处理主键字段,而MySQL则提供了自增长(increment)来实现类似的目的;

但在实际使用过程中发现,MySQL的自增长有诸多的弊端:不能控制步长、开始索引、是否循环等;若需要迁移数据库,则对于主键这块,也是个头大的问题。

本文记录了一个模拟Oracle序列的方案,重点是想法,代码其次。

Oracle序列的使用,无非是使用.nextval和.currval伪列,基本想法是:

1、MySQL中新建表,用于存储序列名称和值;

2、创建函数,用于获取序列表中的值;

具体如下:

表结构为:

drop

table

if

exists

sequence;

create

table

sequence

(

seq_name

VARCHAR(50)

NOT

NULL,

--

序列名称

current_val

INT

NOT

NULL,

--当前值

increment_val

INT

NOT

NULL

DEFAULT

1,

--步长(跨度)

PRIMARY

KEY

(seq_name)

);

实现currval的模拟方案

create

function

currval(v_seq_name

VARCHAR(50))

returns

integer

begin

declare

value

integer;

set

value

=

0;

select

current_value

into

value

from

sequence

where

seq_name

=

v_seq_name;

return

value;

end;

函数使用为:select

currval('MovieSeq');

实现nextval的模拟方案

create

function

nextval

(v_seq_name

VARCHAR(50))

return

integer

begin

update

sequence

set

current_val

=

current_val

+

increment_val

where

seq_name

=

v_seq_name;

return

currval(v_seq_name);

end;

函数使用为:select

nextval('MovieSeq');

增加设置值的函数

create

function

setval(v_seq_name

VARCHAR(50),

v_new_val

INTEGER)

returns

integer

begin

update

sequence

set

current_val

=

v_new_val

where

seq_name

=

v_seq_name;

return

currval(seq_name);

同理,可以增加对步长操作的函数,在此不再叙述。

注意语法,数据库字段要对应上

use

bvboms;

DELIMITER

$$

create

function

setval(v_seq_name

VARCHAR(50),

v_new_val

INTEGER)

returns

integer

begin

update

sequence

set

current_val

=

v_new_val

where

seq_name

=

v_seq_name;

return

currval(seq_name);

end

$$

DELIMITER

$$

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

您可能感兴趣的文章:mysql实现sequence功能的代码Can''t

connect

to

local

MySQL

through

socket

''/tmp/mysql.sock''解决方法Mysql常用函数大全(分类汇总讲解)利用MySQL主从配置实现读写分离减轻数据库压力mysql+spring+mybatis实现数据库读写分离的代码配置Golang中如何对MySQL进行操作详解将图片储存在MySQL数据库中的几种方法MySQL存储文本和图片的方法Ubuntu上mysql的安装及使用(通用版)nodejs同步调用获取mysql数据时遇到的大坑

谁能给个mysql创建序列sequence 和触发器的例子

你可以参考下面事例

mysql create table animals(id int not null auto_increment primary key, name cha

r(32) not null);

Query OK, 0 rows affected (0.08 sec)

mysql insert into animals(name) values ('dog'), ('cat');

Query OK, 2 rows affected (0.00 sec)

Records: 2  Duplicates: 0  Warnings: 0

mysql select * from animals;

+----+------+

| id | name |

+----+------+

|  1 | dog  |

|  2 | cat  |

+----+------+

2 rows in set (0.00 sec)

mysql CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));

mysql CREATE TRIGGER ins_sum BEFORE INSERT ON account

- FOR EACH ROW SET @sum = @sum + NEW.amount;

mysql SET @sum = 0;

mysql INSERT INTO account VALUES(137,14.98),(141,1937.50),(97,-100.00);

mysql SELECT @sum AS 'Total amount inserted';

+-----------------------+

| Total amount inserted |

+-----------------------+

| 1852.48               |

+-----------------------+

mysql DROP TRIGGER account.ins_sum;


文章名称:mysql怎么创建序列,数据库如何创建序列
当前URL:http://cqcxhl.com/article/hogjhc.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP