Как решить java.lang.ClassCastException: java.lang.String не может быть приведен к java.lang.Integer в Spring - PullRequest
0 голосов
/ 07 ноября 2018

MenuModel

@Entity
@Table(name="M_MENU", uniqueConstraints={@UniqueConstraint(columnNames={"NAME"})})

public class MenuModel {

private Integer id;
private String code;
private String name;
private String controller;
private Integer parent_id;  

@Id
@Column(name="ID")
@GeneratedValue(strategy=GenerationType.TABLE, generator="M_MENU")
@TableGenerator(name="M_MENU", table="M_SEQUENCE",
                    pkColumnName="SEQUENCE_NAME", pkColumnValue="M_MENU_ID",
                    valueColumnName="SEQUENCE_VALUE", allocationSize=1, initialValue=0
                )
public Integer getId() {
    return id;
}
public void setId(Integer id) {
    this.id = id;
}

@Column(name="CODE")
public String getCode() {
    return code;
}
public void setCode(String kode) {
    this.code = kode;
}

@Column(name="NAME")
public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}

@Column(name="CONTROLLER")
public String getController() {
    return controller;
}
public void setController(String controller) {
    this.controller = controller;
}

@Column(name="PARENT_ID")
public Integer getParent_id() {
    return parent_id;
}
public void setParent_id(Integer parent_id) {
    this.parent_id = parent_id;
}   
}

UserAccessModel

@Entity
@Table(name="M_USER_ACCESS")
public class UserAccessModel {

private Integer id;

//join table role
private Integer idRole;
private RoleModel roleModel;

//join table menu
private Integer idMenu;
private MenuModel menuModel;

@Id
@Column(name="ID")
@GeneratedValue(strategy=GenerationType.TABLE, generator="M_USER_ACCESS")
@TableGenerator(name="M_USER_ACCESS", table="M_SEQUENCE",
                    pkColumnName="SEQUENCE_NAME", pkColumnValue="M_USER_ACCESS_ID",
                    valueColumnName="SEQUENCE_VALUE", allocationSize=1, initialValue=0
                )
public Integer getId() {
    return id;
}
public void setId(Integer id) {
    this.id = id;
}

@Column(name="ID_ROLE")
public Integer getIdRole() {
    return idRole;
}
public void setIdRole(Integer idRole) {
    this.idRole = idRole;
}

@ManyToOne
@JoinColumn(name="ID_ROLE", nullable=true, updatable=false, insertable=false)
public RoleModel getRoleModel() {
    return roleModel;
}
public void setRoleModel(RoleModel roleModel) {
    this.roleModel = roleModel;
}

@Column(name="ID_MENU")
public Integer getIdMenu() {
    return idMenu;
}
public void setIdMenu(Integer idMenu) {
    this.idMenu = idMenu;
}

@ManyToOne
@JoinColumn(name="ID_MENU", nullable=true, updatable=false, insertable=false)
public MenuModel getMenuModel() {
    return menuModel;
}
public void setMenuModel(MenuModel menuModel) {
    this.menuModel = menuModel;
}
}

MenuDaoImpl

@Override
public List<MenuModel> searchByRole(Integer idRole) {
    // TODO Auto-generated method stub
    Session session = this.sessionFactory.getCurrentSession();      

    List<MenuModel> menuModelListRole = new ArrayList<MenuModel>();

    Criteria userAccessCriteria = session.createCriteria(UserAccessModel.class,"UA");
    Criteria menuCriteria =  userAccessCriteria.createCriteria("menuModel","M");
    userAccessCriteria.add(Restrictions.eq("idRole", ""+idRole+""));

    ProjectionList properties = Projections.projectionList();
    properties.add(Projections.property("M.id"));
    properties.add(Projections.property("M.name"));
    properties.add(Projections.property("M.code"));
    properties.add(Projections.property("M.controller"));
    properties.add(Projections.property("M.parent_id"));

    menuCriteria.setProjection(properties);
    menuModelListRole = menuCriteria.list();


    return menuModelListRole;
}

Я хочу получить результат следующего sql:

выберите M.ID ID, M.NAME NAME, M.CODE CODE, M.CONTROLLER CONTROLLER, M.PARENT_ID PARENT из M_MENU M присоединиться к M_USER_ACCESS UA на UA.ID_MENU = M.ID, где UA.ID_ROLE = "+ idRole +"

Я получил ошибку в методе searchByRole в menuModelListRole = menuCriteria.list();. Как я могу решить проблему?

1 Ответ

0 голосов
/ 07 ноября 2018

Здесь private Integer idRole; имеет тип Integer, но вы передаете idRole как строку в Restrictions.eq("idRole", ""+idRole+""). ТАК вы получаете java.lang.String cannot be cast to java.lang.Integer in Spring

Изменение значения ограничения с Restrictions.eq("idRole", ""+idRole+"") на Restrictions.eq("idRole", idRole) должно решить вашу проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...