native:根据底层数据库对自动生成标识符的能力来选择identity、sequence、hilo三种生成器的一种,适合跨数据库平台开发。适用于代理主键。
identity:采用底层数据库本身提供的主键生成标识符,条件是数据库支持自动增长数据类型。在DB2、MYSQL、MS SQL Server、Sybase、HypersonicSQL数据库中可以使用该生成器,该生成器要求数据库中把主键定义为自增长类型。适用于代理主键。
sequence:根据底层数据库序列生成标识符。条件是数据库支持序列。适用于代理主键。
uuid:采用128位的UUID算法生成标识符,在网络环境中生成唯一的字符串标识符。在数据库中,很少以此为主键,太占空间。
increment:用于long、short 或 int类型,有hibernate自动以递增的方式生成唯一标识符,每次增量为1.只有当没有其他进程相同一张表中插入数据时才可以使用,不能再集群环境下使用。适用于代理主键。
assigned:有java程序负责生成标识符,如果不指定id元素的generator属性,则默认使用该主键生成策略。适用于自然主键。
代理主键(逻辑主键):只用于区分数据库中的记录,不参与程序的业务逻辑。
自然主键(业务主键):不仅区分数据库中的记录,也参与程序的业务逻辑。其设计一般都有规律。