Я создаю веб-приложение, используя SpringBoot, Hibernate и React. У меня не было проблем с использованием весенних обучающих программ для создания «нормальных» объектов с автоматически сгенерированными идентификаторами. Для моей пользовательской таблицы я не вижу необходимости иметь автоинкрементный идентификатор, для которого потребуется отдельный индекс, поэтому я пытаюсь сделать имя пользователя Первичным ключом. (Это также облегчит расшифровку всех ссылок). Вот моя модель пользователя:
import java.io.Serializable;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import com.fasterxml.jackson.annotation.JsonIgnore;
import lombok.Data;
@Data
@Entity
@Table(name="user")
public class User implements Serializable {
/**
*
*/
private static final long serialVersionUID = -3924062441897826838L;
@Id
@Column(name="username")
private String userName;
@Column(name="password")
private String password;
@Column(name="role")
private String role;
@Column(name="first_name")
private String firstName;
@Column(name="last_name")
private String lastName;
@Column(name="country")
private String country;
@Column(name="enabled")
private boolean enabled;
@JsonIgnore
@ManyToMany(fetch = FetchType.LAZY,
cascade = {
CascadeType.PERSIST,
CascadeType.MERGE
},
mappedBy = "users")
private Set<Project> projects = new HashSet<>();
@JsonIgnore
@OneToMany(cascade = CascadeType.ALL,
fetch = FetchType.LAZY,
mappedBy = "createUser")
private Set<Project> createdProjects = new HashSet<>();
private User() { }
public User(String userName) {
this.userName = userName;
}
@Override
public String toString() {
return "User [userName="+ userName+",firstName="+firstName+"]";
}
}
Мне не удается получить доступ к первичному ключу (userName) по основным маршрутам. (this.props.user.userName ... в реакции). Я понимаю, что он встроен в _links, но есть ли способ получить к нему доступ для моей страницы списка?
**
* User Object
*/
class User extends React.Component {
constructor(props) {
super(props);
this.handleDelete = this.handleDelete.bind(this);
}
handleDelete() {
this.props.onDelete(this.props.user);
}
render() {
return (
<tr>
<td>**{this.props.user.userName} is BLANK**</td>
<td>{this.props.user.firstName}</td>
<td>{this.props.user.lastName}</td>
<td>{this.props.user.enabled}</td>
<td>
<button onClick={this.handleDelete}>Delete</button>
</td>
</tr>);
}
}
Является ли добавление идентификатора автоматического приращения для пользователя единственным способом? Вся помощь очень ценится. Спасибо!
ОБНОВЛЕНИЕ: Вот вывод console.log (this.props.user):
Object
_links: Object
createdProjects: {href: "http://localhost:8080/api/users/testUserName/createdProjects"}
projects: {href: "http://localhost:8080/api/users/testUserName/projects"}
self: {href: "http://localhost:8080/api/users/testUserName"}
user: {href: "http://localhost:8080/api/users/testUserName"}
Object Prototype
country: "TestCountry"
enabled: true
firstName: "TestName"
lastName: "TestLastName"
password: "testPword"
role: "testrole"