当前位置: 首页 > 面试题库 >

自动和手动设置ID(PK)生成值

龙玄天
2023-03-14
问题内容

我想将用户持久保存到数据库中,并使用IDENTITY生成类型创建的User的ID(PK)的当前方案。例如

@Entity
@Table(name = "USER_PROFILES", uniqueConstraints = @UniqueConstraint(columnNames = "USERNAME"))
public class UserProfiles implements java.io.Serializable {
private Long id;
private String username;
private String password;



public UserProfiles() {
}



@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name = "ID", unique = true, nullable = false, precision = 20, scale = 0)
public Long getId() {
    return this.id;
}

public void setId(Long id) {
    this.id = id;
}

@Column(name = "USERNAME", unique = true, nullable = false, length = 32)
public String getUsername() {
    return this.username;
}

public void setUsername(String username) {
    this.username = username;
}

@Column(name = "PASSWORD", nullable = false, length = 32)
public String getPassword() {
    return this.password;
}

public void setPassword(String password) {
    this.password = password;
}

}

但我想Create Id(PK)在以下情况下进行操作:1)用户Id(PK)明确设置。2)如果未设置用户,Id(PK)则将自动分配它,并且它必须是唯一的。

请建议我一些可用的选项,以便我解决。谢谢。


问题答案:

您可以为此目的定义您的自定义ID生成器,如本SOAnswer中指出的那样

它的代码如下所示:

@Id
@Basic(optional = false)
@GeneratedValue(strategy=GenerationType.IDENTITY, generator="IdOrGenerated")
@GenericGenerator(name="IdOrGenerated",strategy="....UseIdOrGenerate")
@Column(name = "ID", unique = true, nullable = false, precision = 20, scale = 0)
public Long getId(){..}

  public class UseIdOrGenerate extends IdentityGenerator {    
    @Override
    public Serializable generate(SessionImplementor session, Object obj) throws HibernateException {
        if (obj == null) throw new HibernateException(new NullPointerException()) ;

        if ((((EntityWithId) obj).getId()) == null) {//id is null it means generate ID
            Serializable id = super.generate(session, obj) ;
            return id;
        } else {
            return ((EntityWithId) obj).getId();//id is not null so using assigned id.

        }
    }
}


 类似资料:
  • 问题内容: 有人知道如何从1开始生成,以便下一个对象具有2,依此类推吗? 我尝试了以下方法,但不起作用: 问题答案: 您需要一个 静态的 类成员来跟踪上次使用的索引。确保还实现一个复制构造函数: 更新: 正如@JordanWhite建议的那样,您可能希望使static计数器成为 atomic ,这意味着可以安全地同时使用(即一次在多个线程中使用)。为此,将类型更改为: 增量读取和复位操作变为:

  • 问题内容: 我在Employee类中有以下定义 现在,我想使用现有员工ID导入现有员工。即使在保存之前设置了员工ID,也会忽略分配的ID,并存储自动递增的ID。我们如何覆盖呢? 问题答案: 我编写了自己的生成器来解决此问题。 并像这样使用它:(替换包名)

  • 问题内容: 有没有一种方法可以在SWT小部件上自动生成ID,以便UI测试可以引用它们?我知道我可以使用seData手动设置ID,但是我想以某种通用的方式为现有应用程序实现此功能。 问题答案: 您可以使用和为应用程序中所有外壳递归分配ID 。 设置ID 您可以使用方法访问应用程序中所有活动的(未处置的)Shell 。您可以遍历每个子项的所有子项,并使用方法为每个子项分配一个ID 。 如果是,则它可能

  • 本文向大家介绍mybatis自动生成时如何设置不生成Example类详解,包括了mybatis自动生成时如何设置不生成Example类详解的使用技巧和注意事项,需要的朋友参考一下 本文主要给大家介绍了关于mybatis自动生成时不生成Example类的相关内容,分享出来供大家参考学习,下面来看看详细的介绍: 只需要在配置要生成的table表中添加几个配置属性就行了。 在generatorConfi

  • 问题内容: 嗨,我编写了这样的代码 但是我从DAO手动设置了它,例如“ e.setUserID(01);”。否则将不插入行是否有任何过程来获取ID值并检索自动生成的值。我想我会得到一些帮助 问题答案: 采用

  • 本文向大家介绍ThinkPHP3.1新特性之动态设置自动完成和自动验证示例,包括了ThinkPHP3.1新特性之动态设置自动完成和自动验证示例的使用技巧和注意事项,需要的朋友参考一下 以往在ThinkPHP3.1版本之前,如果需要设置自动验证或者自动完成,一般来说必须定义在模型中,或者通过setProperty方法动态设置属性来完成,这样做的缺点是不太方便动态改变和调整。 ThinkPHP3.1版