如何获得mysql数据库自增长主键的值?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何获得mysql数据库自增长主键的值?相关的知识,希望对你有一定的参考价值。

this.employee_id = employee_id; 其它几个属性的getter和setter省略,这里我们要用到ejb3-persistence.jar,JPA的注解类就在这个包中,下面详细说明上面使用到的注解。@Entity:通过@Entity注解将一个类声明为一个实体bean@Table:通过 @Table注解可以为实体bean映射指定表,name属性表示实体所对应表的名称,如果没有定义 @Table,那么系统自动使用默认值:实体的类名(不带包名)@Id:用于标记属性的主键@Column:表示持久化属性所映射表中的字段,如果属性名与表中的字段名相同,则可以省略@Column注解,另外有两种方式标记,一是放在属性前,另一种是放在getter方法前,例如:@Column(name = EMPLOYEE_NAME)private String employee_name; 或者@Column(name = EMPLOYEE_NAME)public String getEmployee_name() return employee_name; 这两种方式都是正解的,根据个人喜好来选择。大象偏向于第二种,并且喜欢将属性名与字段名设成一样的,这样可以省掉@Column注解,使代码更简洁。@TableGenerator:表生成器,将当前主键的值单独保存到一个数据库表中,主键的值每次都是从指定的表中查询来获得,这种生成主键的方式是很常用的。这种方法生成主键的策略可以适用于任何数据库,不必担心不同数据库不兼容造成的问题。大象推荐这种方式管理主键,很方便,集中式管理表的主键,而且更换数据库不会造成很大的问题。各属性含义如下:name:表示该表主键生成策略的名称,这个名字可以自定义,它被引用在@GeneratedValue中设置的generator值中table:表示表生成策略所持久化的表名,说简单点就是一个管理其它表主键的表,本例中,这个表名为GENERATOR_TABLEpkColumnName:表生成器中的列名,用来存放其它表的主键键名,这个列名是与表中的字段对应的pkColumnValue:实体表所对应到生成器表中的主键名,这个键名是可以自定义滴valueColumnName:表生成器中的列名,实体表主键的下一个值,假设EMPLOYEE表中的EMPLOYEE_ID最大为2,那么此时,生成器表中与实体表主键对应的键名值则为3allocationSize:表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50@GeneratedValue:定义主键生成策略,这里因为使用的是TableGenerator,所以,主键的生成策略为GenerationType.TABLE,生成主键策略的名称则为前面定义的”tab-store”。这里大象想说下,网上有很多文章写的是strategy = GenerationType.AUTO或是strategy = GenerationType.SEQUENCE,采用SEQUENCE序列是因为Oracle数据中不支持identity自动增长,要想使用它,还得在数据库中创建一个序列,如果要更换数据库,那将是一个非常麻烦的事情。SEQUENCE生成方式我们暂且不谈,这里说下采用AUTO和IDENTITY的生成方式,本例采用的是SQL Server 2000作为数据库,所以如果想使用AUTO或是IDENTITY生成策略,则一定要对主键加上identity标识,如identity(1,1)。不过对于AUTO来说,是根据不同的数据库选择最合适的自增主键生成策略。如果使用mysql,则主键要定义AUTO_INCREMENT,如果是Oracle,则要创建Sequence来实现自增。不管采用何种生成策略,增、删、改这些方法中一定要加入事务,否则数据是不会添加到数据库中滴~~~这是大象反复测试过的结果! 参考技术A

如果是自增长的话,直接用max函数即可。

如表为:

id     name

1       张三

2       李四

3       王五


其中id为自增长字段,如果要查询目前主键的值,可用如下语句:

select max(id) as id from 表名;

结果显示为:

id

3

就说明目前id的值为3。

参考技术B 2、 select max(id) from tablename

1、mysql_insert_id () ;

Mysql

mysql:
 
自增长是依赖主键的:所以要删除主键,必须先删除自增长
 
创建外键的时候:如果不设置名字   系统自动命名规则:表名_ibfk_1     此处1代表第一个外键   2代表第二个外键。。。。。
 
插入语句:insert into  emp   (具体字段)  values (插入的值);

 

 
 

 

 
 
 
 
mysql乱码问题 : 
String url = (String) ProPerJdbc.proper().getProperty( "jdbc.url" )+"?useUnicode=true&characterEncoding=utf8";
 
 
项目中关于日期的解决办法
1:如果数据库中是date类型      在java中实体类中+添加数据+或者修改时间数据的时候用Timestamp
 
2:如果数据库中用的是number(10)或者number(13)的时候     java的实体类或者+添加时间数据+修改时间数据用long就OK
 
/**********************************************************************************************************************
1、timestap:java中的日期,也可以使用long
数据库中用date就OK
 
  【1】:数据库字段,如果定义的date
              对象里面的时间字段:sql.timestap
              取值:rs.getdate("数据库字段");
              存值:user.get("对象相应字段");
  【2】:数据库字段,如果定义的number(10)
              对象里面的时间字段:long
              取值:rs.getLong("对象相应字段")
              存值:String date 传给后台(工具类转换为long)
 
2、关于sql拼接:在程序中用StringBuffer
 
mysql乱码问题 : 
String url = (String) ProPerJdbc.proper().getProperty( "jdbc.url" )+"?useUnicode=true&characterEncoding=utf8";
 
 
?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
 
 

以上是关于如何获得mysql数据库自增长主键的值?的主要内容,如果未能解决你的问题,请参考以下文章

MySQL数据库8列属性之主键自增长

2020-01-16 控制MYSQL的自增长序列的起始值

如何获取数据表中自增主键的值

Mysql:设置主键自动增长起始值

Navicat for MySQL怎么将设置成外键的ID设置自动增长

Mysql:设置主键自动增长起始值