- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用 Hibernate 在 MySQL 中生成 GUID/UUID。下面是相同的代码:任何人都可以建议我哪里出错了。
public class MainClassLists {
public static void main(String[] args){
Configuration configuration = new Configuration().configure();
ServiceRegistryBuilder registry = new ServiceRegistryBuilder();
registry.applySettings(configuration.getProperties());
ServiceRegistry serviceRegistry = registry.build();
SessionFactory sessionFactory = configuration.buildSessionFactory(serviceRegistry);
Session session = sessionFactory.openSession();
Users userNew = new Users();
userNew.setUserName("StyuytSra");
userNew.setPassword("pyuass");
userNew.setFirstName("sryuyaxcva");
userNew.setLastName("sayuynxca");
userNew.setBirthDate("2000-08-12");
userNew.setGender("f");
userNew.setEmailId("tesuyut@email.com");
userNew.setPhoneNumber(92672);
userNew.setAccountNumber(8878);
userNew.setAddress1("add1");
userNew.setAddress2("add2");
userNew.setCity("SD");
userNew.setCountry("US");
userNew.setZipcode(765);
session.beginTransaction();
session.save(userNew);
Serializable uid= session.getIdentifier(userNew);
System.out.println("User ID : "+userNew.getUserId()+""+uid);
System.out.println();
session.close();
System.exit(0);
}
}
实体类:
@Entity
@Table(name = "users", catalog = "test", schema = "")
public class Users implements Serializable {
@Id
@Column(name = "user_id")
@GeneratedValue(generator = "GUID")
@GenericGenerator(name = "GUID", strategy = "com.List_Test.mainClass.InquisitiveUUIDGenerator")
private String userId;
@Basic(optional = false)
@Column(name = "user_name", unique = true)
private String userName;
@Basic(optional = false)
@Column(name = "password")
private String password;
@Basic(optional = false)
@Column(name = "first_name")
private String firstName;
@Basic(optional = false)
@Column(name = "last_name")
private String lastName;
@Column(name = "birth_date")
private String birthDate;
@Column(name = "gender")
private String gender;
@Column(name = "email_id", unique = true)
private String emailId;
@Column(name = "phone_number")
private Integer phoneNumber;
@Column(name = "account_number", unique = true)
private Integer accountNumber;
@Column(name = "address_1")
private String address1;
@Column(name = "address_2")
private String address2;
@Column(name = "city")
private String city;
@Column(name = "state")
private String state;
@Column(name = "zipcode")
private Integer zipcode;
@Column(name = "country")
private String country;
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public String getBirthDate() {
return birthDate;
}
public void setBirthDate(String birthDate) {
this.birthDate = birthDate;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getEmailId() {
return emailId;
}
public void setEmailId(String emailId) {
this.emailId = emailId;
}
public Integer getPhoneNumber() {
return phoneNumber;
}
public void setPhoneNumber(Integer phoneNumber) {
this.phoneNumber = phoneNumber;
}
public Integer getAccountNumber() {
return accountNumber;
}
public void setAccountNumber(Integer accountNumber) {
this.accountNumber = accountNumber;
}
public String getAddress1() {
return address1;
}
public void setAddress1(String address1) {
this.address1 = address1;
}
public String getAddress2() {
return address2;
}
public void setAddress2(String address2) {
this.address2 = address2;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
public String getState() {
return state;
}
public void setState(String state) {
this.state = state;
}
public Integer getZipcode() {
return zipcode;
}
public void setZipcode(Integer zipcode) {
this.zipcode = zipcode;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
}
Id 生成器类:
public class InquisitiveUUIDGenerator extends UUIDGenerator {
private String entityName;
public void configure(Type type, Properties params, Dialect dialect) {
entityName = params.getProperty(ENTITY_NAME);
super.configure((org.hibernate.type.Type) type, params, dialect);
}
@Override
public Serializable generate(SessionImplementor session, Object object) {
Serializable id = session
.getEntityPersister(entityName, object)
.getIdentifier(object, session);
if (id == null) {
return super.generate(session, object);
} else {
return id;
}
}
}
此外,我尝试在用户表的 MySQL 数据库中插入数据之前使用触发器插入数据,并尝试将其映射到实体类。我映射了它,但是我为生成器提供 key 的 @NaturalId(unique) 键不是唯一的。因此会生成重复的映射。我对生成 GUID 或 UUID 的正确方法感到困惑。如果有人能为我提供一个例子,我将不胜感激。下面是表的 id DB 脚本
CREATE TABLE `users` (
`user_id` varchar(36) NOT NULL,
`user_name` varchar(20) NOT NULL,
`password` varchar(25) NOT NULL,
`first_name` varchar(25) NOT NULL,
`last_name` varchar(25) NOT NULL,
`birth_date` varchar(100) DEFAULT NULL,
`gender` varchar(15) DEFAULT NULL,
`email_id` varchar(50) DEFAULT NULL,
`phone_number` int(10) DEFAULT NULL,
`account_number` int(8) DEFAULT NULL,
`address_1` varchar(50) DEFAULT NULL,
`address_2` varchar(50) DEFAULT NULL,
`city` varchar(15) DEFAULT NULL,
`state` varchar(2) DEFAULT NULL,
`zipcode` int(8) DEFAULT NULL,
`country` varchar(15) DEFAULT NULL,
PRIMARY KEY (`user_id`),
UNIQUE KEY `user_name` (`user_name`),
UNIQUE KEY `email_id` (`email_id`),
UNIQUE KEY `phone_number` (`phone_number`),
UNIQUE KEY `account_number` (`account_number`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
所提供的代码编译并成功运行。 id 已生成但未插入到数据库表中。输出将是这样的:'用户 ID:ab9ffdb1-67ba-4d14-9038-3901d5032ab5ab9ffdb1-67ba-4d14-9038-3901d5032ab5'
最佳答案
我没有使用单独的类来生成 UUID(如我的问题中提到的),而是使用了我在其他堆栈溢出答案中找到的以下注释。我之前尝试过,但没有成功,因为我忘记了开始、结束和提交 session 事务。尽管它生成了 GUID,但它并未保存到数据库中。我必须提交交易才能保存它。下面的代码应该为 ID 进行注释。
@Id
@GeneratedValue(generator = "system-uuid")
@GenericGenerator(name = "system-uuid", strategy = "org.hibernate.id.GUIDGenerator")
@Column(name = "user_id", unique = true)
关于mysql - 能够生成 UUID 但无法将其插入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38209838/
我试图再次将反射的 UUID 转换回实际的 UUID 对象,但找不到方法,当我打印反射值时它看起来是正确的,但在尝试转换时我找不到方法。 package main import ( "fmt"
我想知道 UUID 是否是唯一的,即使它们是在不同的系统上生成的,这些系统可能采用不同的算法。例如,如果您在 MySQL 和 .Net 中生成了一堆 UUID,碰撞的可能性会更高,还是所有系统都使用完
是否可以一个接一个地创建两个重复的 UUID?我不熟悉 UUID 是如何生成的,但我猜想如果您在同一毫秒内从同一 MAC 地址创建了两个单独的 UUID,那么它们将完全相同。这是真的吗? 我想我是在问
当我使用 python uuid 模块中的 UUID() 函数检查我们的测试 uuid 之一时,我遇到了这种奇怪的行为。 从 uuid 导入 UUID uuid1 = UUID('00000000-0
开始使用 java.util.UUID。我的问题是如果我有两个 UUID 变量,比如 u1 和 u2,并且我想检查它们是否相等,我可以安全地使用表达式 u1 == u2 还是必须编写 u1 .equa
我浏览了 python UUID 模块的文档。 >>> uuid.uuid4() UUID('82fe5629-6680-4b13-a4e3-7a082f10e038') >>> uuid.uuid4
我正在创建一个程序,我在其中大量使用 UUID 来识别用户和组等内容。鉴于 UUID 已经被占用的可能性极低,我是否应该担心发生碰撞的可能性? 最佳答案 这在很大程度上取决于 A)您的要求 B)底层实
您应该使用哪个版本的 UUID?我看到很多帖子解释了每个版本的含义,但我很难弄清楚什么最适合哪些应用程序。 最佳答案 有两种不同的方式生成 UUID。 如果您只需要一个唯一 ID,则需要版本 1 或版
我知道我们可以轻松提取 uuid 版本号。有没有可靠的方法来提取时间戳、MAC 地址等信息? 谢谢! 最佳答案 符合标准的 UUID 可能是多种变体之一,它看起来像这样: AAAAAAAA-BBBB-
我可以干净地使用私有(private) UUID 变体/版本吗? 我使用我基本上认为是大整数的随机 UUID。现在,我想生成一个“私有(private)”UUID,它不基于众所周知的 5 个变体/版本
我已阅读 man 页面,但我不明白 name 和 namespace 的用途。 For version 3 and version 5 UUIDs the additional command lin
我目前正在项目中使用 boost::uuids::uuid,并且我想序列化包含 boost::uuids::uuid 的对象。我尝试了下面的简单示例,但出现错误: /usr/include/boost
我正在使用 Datastax Java 驱动程序在 Cassandra 数据库中执行基本的插入语句。我的主键列是uuid类型。从我在官方文档中看到的,在 Cassandra 中调用 uuid() 函数
会抛出异常吗? UUID() 是否会悄无声息地失败?是否有任何情况下“myStatus”来自 myStatus = True myUUID = uuid.UUID( someWeirdValue )
在我的 Android 应用程序中,我有这种采用 UUID 的方法。不幸的是,当我这样做时: OverviewEvent overviewevent = eventAdapter.getOvervie
我有一个简单的 mongo 迁移框架,它正在执行一些传递给它的脚本。 现在我想将我的 LUUID 迁移到 UUID。我写了以下内容: function fixIds(collectionName) {
我有一个非常奇怪的问题是我得到一个有效的 UUID 不是一个有效的 UUID,例如: 'fd31b6b5-325d-4b65-b496-d7e4d16c8a93' is not a valid UUI
我正在测试 Goa对于一个 API。我想使用 uuid 作为 ID 数据类型。我在 controller.go 中修改了以下函数: // Show runs the show action. func
我有一个包含 uuid 和系统列的表。我需要一个查询来仅返回具有 system=1 的 uuid,而不返回具有 system= 1 和 2 的 uuid 最佳答案 SELECT * FROM
我很想了解在 Avro 中编码一种非常特定类型的数据的最佳实践:UUID。 最佳答案 到目前为止,我发现的唯一方法是定义自定义 UUID: { "namespace" : "your.namesp
我是一名优秀的程序员,十分优秀!