1

私はHibernateを初めて使用するので、質問が重複していたり​​愚かだったりする場合はご容赦ください。Hibernate 3.3.0PostgreSQL DBを使用しています。現在、私は2つのエンティティを持っています。User.roleIDPKで、Role.idFKであるような方法で@OneToManyアノテーションに関連付ける必要があります (ユーザーは 1 つのロールのみを持つことができ、同じロールを複数のユーザーに割り当てることができます)。また、Google を検索していたときに、何らかの理由で、アノテーションの関連付けを含むすべての例で、アノテーション付きフィールドが Set として宣言されていることがわかりました。これを説明してください。アドバイスありがとうございます。

ナザール。

ユーザー エンティティ:

package com.dataart.mediaportal.model;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;


@Entity
@Table(name = "users")
public class User implements Serializable {

    private int id;
    private String login;
    private String password;
    private String firstName;
    private String lastName;
    private int roleID;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "user_id", unique = true)
    public int getId() {
        return id;
    }

    @Column(name = "user_login", nullable=false, unique = true, length = 20 )
    public String getLogin() {
        return login;
    }

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

    @Column(name = "user_name", nullable = true)
    public String getFirstName() {
        return firstName;
    }

    @Column(name = "user_lastname", nullable = true)
    public String getLastName() {
        return lastName;
    }

    @Column(name = "role_id", nullable = false)
    public int getRoleID() {
        return roleID;
    }

    public void setRoleID(int roleID) {
        this.roleID = roleID;
    }

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

    public void setLogin(String login) {
        this.login = login;
    }

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

    public void setFirstName(String firstname) {
        this.firstName = firstname;
    }

    public void setLastName(String lastname) {
        this.lastName = lastname;
    }
}

ロール エンティティ:

package com.dataart.mediaportal.model;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;


@Entity
@Table(name = "roles")
public class Role implements Serializable {

    private int id;
    private String role;

    @Id
    @Column(name = "role_id", nullable = false)
    public int getId() {
        return id;
    }

    @Column(name = "role_name", nullable = false)
    public String getRole() {
        return role;
    }

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

    public void setRole(String role) {
        this.role = role;
    }

}

DB スクリプト:

DROP TABLE IF EXISTS users CASCADE;
DROP TABLE IF EXISTS roles CASCADE;
DROP TABLE IF EXISTS albums CASCADE;
DROP TABLE IF EXISTS images CASCADE;

CREATE TABLE users
(
  user_login character varying(20) NOT NULL,
  user_password character varying(32) NOT NULL,
  user_name character varying,
  user_lastname character varying,
  role_id integer DEFAULT 0,
  user_id serial NOT NULL,
  CONSTRAINT pk_user_id PRIMARY KEY (user_id),
  CONSTRAINT users_user_login_key UNIQUE (user_login)
)
WITH (
  OIDS=FALSE
);
ALTER TABLE users
  OWNER TO postgres;

CREATE TABLE roles
(
  role_id integer NOT NULL,
  role_name character varying NOT NULL DEFAULT 'user'::character varying,
  CONSTRAINT role_id_pk PRIMARY KEY (role_id)
)
WITH (
  OIDS=FALSE
);
ALTER TABLE roles
  OWNER TO postgres;

INSERT INTO roles
VALUES ( 0, 'user' ),
( 1, 'admin' );

-- testlog - testpass
-- user - password
INSERT INTO users
VALUES ( 'testlog', '179ad45c6ce2cb97cf1029e212046e81', 'Nazar', 'Sobchuk', 1),
('user', '5f4dcc3b5aa765d61d8327deb882cf99', 'unknown', 'unknown', 0);


CREATE TABLE albums
(
  album_name character varying NOT NULL,
  user_id integer,
  album_id serial NOT NULL,
  CONSTRAINT album_id PRIMARY KEY (album_id),
  CONSTRAINT user_id FOREIGN KEY (user_id)
      REFERENCES users (user_id) MATCH SIMPLE
      ON UPDATE NO ACTION ON DELETE NO ACTION
)
WITH (
  OIDS=FALSE
);
ALTER TABLE albums
  OWNER TO postgres;
CREATE INDEX fki_user_id
  ON albums
  USING btree
  (user_id);

INSERT INTO albums VALUES ('Main Album', 1);

CREATE TABLE images
(
  img bytea,
  img_name character varying NOT NULL,
  album_id integer,
  img_id serial NOT NULL,
CONSTRAINT images_img_name UNIQUE(img_name),
  CONSTRAINT album_id FOREIGN KEY (album_id)
      REFERENCES albums (album_id) MATCH SIMPLE
      ON UPDATE NO ACTION ON DELETE NO ACTION

)
WITH (
  OIDS=FALSE
);
ALTER TABLE images
  OWNER TO postgres;

CREATE INDEX fki_album_id
  ON images
  USING btree
  (album_id);

ユーザーを挿入:

public boolean insertUser(User user) {
    factory = getSessionFactory();
    session = factory.openSession();
    tx = session.beginTransaction();
    Query queryResult = session.createQuery("from User");
    List<User> userList = queryResult.list();
    for (User u : userList) {
        if (u.getLogin().equalsIgnoreCase(user.getLogin())) {
            FacesContext.getCurrentInstance().addMessage(null,
                    new FacesMessage("User_is_already_registered"));
            return false;
        }
    }
    session.save(user);
    tx.commit();
    session.close();
    return true;
}
4

1 に答える 1

1

以下のように、ユーザーを Role に 1 対多の関係として追加します。セッターも作成します

private List<User> userList;
    @OneToMany(mappedBy = "role")
    public List<User> getUserList() {
        return userList;
    }

以下のように、1 対 1 の関係と同じ数のロールをユーザーに追加します。

private Role role;
    @ManyToOne
    public Role getRole() {
        return role;
    }
于 2013-07-25T05:55:40.770 に答える