我使用JHipster创建了我的应用程序。当我尝试通过TournamentQueryService获取比赛列表时,出现此错误:
TournamentQueryService.findByCriteria()中的异常,原因为= 'org.hibernate.HibernateException:无法访问lob流'和 exception ='无法访问lob流;嵌套异常为 org.hibernate.HibernateException:无法访问lob流'
这是过滤器和Page对象:
按条件查找:TournamentCriteria {},页面:页面请求[编号: 0,大小8,排序:startDate:DESC]
因此,它只获得8个首个锦标赛。
这是锦标赛课程:
@Entity
@Table(name = "tournament")
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@Document(indexName = "tournament")
public class Tournament extends AbstractAuditingEntity implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "sequenceGenerator")
@SequenceGenerator(name = "sequenceGenerator")
private Long id;
@Column(name = "name")
private String name;
@Column(name = "location")
private String location;
@Column(name = "url")
private String url;
@Column(name = "start_date")
private ZonedDateTime startDate;
@Column(name = "end_date")
private ZonedDateTime endDate;
@Column(name = "entry_fee")
private Double entryFee;
@Column(name = "prize")
private Double prize;
@Column(name = "goods")
private String goods;
@Column(name = "favorite_rating")
private Long favoriteRating;
@Column(name = "participants_number")
private Integer participantsNumber;
@Column(name = "finished")
private Boolean finished;
@Column(name = "view_only")
private Boolean viewOnly;
@Column(name = "image")
private String image;
@Column(name = "description")
private String description;
@Column(name = "teams_applied")
private String teamsApplied;
@Lob
@Column(name = "schedule")
private String schedule;
@Lob
@Column(name = "prize_distribution")
private String prizeDistribution;
@Lob
@Column(name = "contacts")
private String contacts;
@Lob
@Column(name = "rules")
private String rules;
@OneToMany(mappedBy = "tournament", fetch = FetchType.LAZY)
@JsonIgnore
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
private Set<Stream> streams = new HashSet<>();
@ManyToMany(fetch = FetchType.EAGER)
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@JoinTable(name = "tournament_platforms", joinColumns = @JoinColumn(name = "tournaments_id", referencedColumnName = "id"), inverseJoinColumns = @JoinColumn(name = "platforms_id", referencedColumnName = "id"))
private Set<Platform> platforms = new HashSet<>();
@ManyToOne
private Game game;
@ManyToOne
private TournamentStatus status;
@ManyToOne(fetch = FetchType.LAZY)
private EntryType entryType;
@ManyToOne(fetch = FetchType.LAZY)
private TournamentFormat format;
@ManyToOne
private Region region;
@ManyToOne(fetch = FetchType.LAZY)
private GameMode gameMode;
@ManyToOne(fetch = FetchType.LAZY)
private PrizeType prizeType;
@ManyToOne
private Organizer organizer;
@ManyToOne(fetch = FetchType.LAZY)
private TournamentStage stage;
@ManyToOne
private HostPlatform hostPlatforms;
@ManyToOne(fetch = FetchType.LAZY)
private TournamentType type;
@ManyToOne
private PlayType playType;
@ManyToOne
private Currency currency;
@ManyToOne
private Country country;
这是调用休眠模式的方法:
@Transactional(readOnly = true)
public Page<Tournament> findByCriteria(TournamentCriteria criteria, Pageable page) {
log.info("find by criteria : {}, page: {}", criteria, page);
final Specifications<Tournament> specification = createSpecification(criteria);
Page<Tournament> result = tournamentRepository.findAll(specification, page);
return result;
}
答案 0 :(得分:1)
在hiberante会话关闭时是否可以尝试访问Lob
属性?
尝试将您的@Lob
属性替换为以下内容:
@Basic(fetch=FetchType.EAGER) @Lob
并检查错误是否仍然存在。