mysql是没有序列的,我最近刚做完一个项目也是从oralce移植到mysql数据库上,oracle中 HIbernate配置都是这样
创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、网站制作、南和网络推广、微信平台小程序开发、南和网络营销、南和企业策划、南和品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供南和建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
generator class="sequence"
param name="sequence"SEQUENCE_CHILDREM_ARCHIVE_ID/param
/generator
,到移植到mysql数据库中之后
generator class="identity"/generator
identity或者是increment都是可以滴,前提是你mysql表中的主键是auto_increatement的int类型的。
1、运行“Navicat Premium”数据库管理工具。
2、新建MySQL数据库连接,点击“连接--MySQL”。
3、连接MySQL服务器,建议先做“连接测试”,其次在“确定”连接。
4、注:若连接非本地MySQL服务器,首先要ping通被连服务器IP,其次被连服务器准予远程连接MySQL数据库。
5、双击“本地MySQL数据库”打开数据库,右击鼠标后选择“新建数据库”。
新建数据库,填写数据库名(必填)、字符集(可空)、排序规则(可空),最后"确定"完成test数据库创建。
注:若字符集、排序规则为空,数据库创建后会自动添加上。
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是实现不了的。建议你考虑别的办法吧,或由一些变通的方式实现。
使用函数创建自增序列管理表(批量使用自增表,设置初始值,自增幅度)
比如说你创建了一个表userinfos
create table userinfos(
userid int primary key,
username varchar(20)
);
//给userinfos添加序列
update userinfos set userid = last_insert_id(userid+1);
//然后查询序列
select last_insert_id();
或者也可以这样
create table userinfos(
userid int primary key not null auto_increment,
username varchar(20)
);
序列只有db2
oracle有,mysql没有序列的,不过你可以给你所所创建的表的主键设置为自增。
例如
create
table
A
(
id
int(20)
auto_increment
)
不过设置为自增的键必须是数值类型的。