result = FinderCacheUtil.getResult(FINDER_PATH_FETCH_BY_USERIDANDCERTIFICATEID,
finderArgs, this);
}
if (result instanceof LFCertificateUser) {
LFCertificateUser lfCertificateUser = (LFCertificateUser) result;
if (!Validator.equals(userID, lfCertificateUser.getUserID()) ||
!Validator.equals(certificateID,
lfCertificateUser.getCertificateID())) {
result = null;
}
}
if (result == null) {
StringBundler query = new StringBundler(4);
query.append(_SQL_SELECT_LFCERTIFICATEUSER_WHERE);
if (userID == null) {
query.append(_FINDER_COLUMN_USERIDANDCERTIFICATEID_USERID_NULL_2);
} else {
query.append(_FINDER_COLUMN_USERIDANDCERTIFICATEID_USERID_2);
}
if (certificateID == null) {
query.append(_FINDER_COLUMN_USERIDANDCERTIFICATEID_CERTIFICATEID_NULL_2);
} else {
query.append(_FINDER_COLUMN_USERIDANDCERTIFICATEID_CERTIFICATEID_2);
}
String sql = query.toString();
Session session = null;
try {
session = openSession();
Query q = session.createQuery(sql);
QueryPos qPos = QueryPos.getInstance(q);
if (userID != null) {
qPos.add(userID.longValue());
}
if (certificateID != null) {
qPos.add(certificateID.longValue());
}
List<LFCertificateUser> list = q.list();
if (list.isEmpty()) {
FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_USERIDANDCERTIFICATEID,
finderArgs, list);
} else {
if ((list.size() > 1) && _log.isWarnEnabled()) {
_log.warn(
"LFCertificateUserPersistenceImpl.fetchByUserIDAndCertificateID(Long, Long, boolean) with parameters (" +
StringUtil.merge(finderArgs) +
") yields a result set with more than 1 result. This violates the logical unique restriction. There is no order guarantee on which result is returned by this finder.");
}
LFCertificateUser lfCertificateUser = list.get(0);
result = lfCertificateUser;
cacheResult(lfCertificateUser);
if ((lfCertificateUser.getUserID() != userID) ||
(lfCertificateUser.getCertificateID() != certificateID)) {
FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_USERIDANDCERTIFICATEID,
finderArgs, lfCertificateUser);
}
}
} catch (Exception e) {