當前位置: 首頁>>代碼示例>>Java>>正文


Java EntityManager.unwrap方法代碼示例

本文整理匯總了Java中javax.persistence.EntityManager.unwrap方法的典型用法代碼示例。如果您正苦於以下問題:Java EntityManager.unwrap方法的具體用法?Java EntityManager.unwrap怎麽用?Java EntityManager.unwrap使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.persistence.EntityManager的用法示例。


在下文中一共展示了EntityManager.unwrap方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getColumnNameToIndexMap

import javax.persistence.EntityManager; //導入方法依賴的package包/類
public static Map<String, Integer> getColumnNameToIndexMap(final String queryString, final EntityManager em) throws SQLException {

        final Session session = em.unwrap(Session.class); // ATTENTION! This is Hibernate-specific!
        final AtomicReference<ResultSetMetaData> msRef = new AtomicReference<>();
        session.doWork((c) -> {
            try (final PreparedStatement statement = create(c, queryString)) {
                // I'm not setting parameters here, because I just want to find out about the return values' column names
                msRef.set(statement.getMetaData());
            }
        });
        final ResultSetMetaData metaData = msRef.get();
        // LinkedHashmap preserves order of insertion:
        final Map<String, Integer> columnNameToColumnIndex = new LinkedHashMap<>();
        for (int t = 0; t < metaData.getColumnCount(); ++t) {
            // important, first index in the metadata is "1", the first index for the result array must be "0"
            columnNameToColumnIndex.put(metaData.getColumnName(t + 1), t);
        }
        return columnNameToColumnIndex;
    }
 
開發者ID:napstr,項目名稱:SqlSauce,代碼行數:20,代碼來源:DbUtils.java

示例2: getJdbcConnection

import javax.persistence.EntityManager; //導入方法依賴的package包/類
@Override
public ConnectionHandle getJdbcConnection(EntityManager entityManager, boolean readOnly)
		throws PersistenceException, SQLException {

	Connection con = entityManager.unwrap(Connection.class);
	return (con != null ? new SimpleConnectionHandle(con) : null);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:8,代碼來源:EclipseLinkJpaDialect.java

示例3: getDB

import javax.persistence.EntityManager; //導入方法依賴的package包/類
public static org.jpos.ee.DB getDB(EntityManager entityManager, Context ctx)
{
    ProxyFactory factory = new ProxyFactory();
    factory.setSuperclass(org.jpos.ee.DB.class);
    Class aClass = factory.createClass();
    final org.jpos.ee.DB newInstance;
    try
    {
        newInstance = (org.jpos.ee.DB) aClass.newInstance();
    }
    catch (InstantiationException | IllegalAccessException e)
    {
        throw new IllegalStateException("Could not create proxy", e);
    }

    MethodHandler methodHandler = (self, overridden, proceed, args) ->
    {
        if (overridden.getName().equals("session"))
        {
            return entityManager.unwrap(Session.class);
        }
        if (overridden.getName().equals("save"))
        {
            entityManager.persist(args[0]);
            return null;
        }
        if (overridden.getName().equals("saveOrUpdate"))
        {
            return entityManager.merge(args[0]);
        }
        if (overridden.getName().equals("delete"))
        {
            entityManager.remove(args[0]);
            return null;
        }
        else if (Arrays.asList(validMethods).contains(overridden.getName()))
        {
            return proceed.invoke(newInstance, args);
        }
        else
        {
            throw new IllegalStateException(
                "Method " + overridden.getName() + " cannot be accessed from Transaction " +
                "Participant");
        }
    };

    ((ProxyObject) newInstance).setHandler(methodHandler);
    return newInstance;
}
 
開發者ID:vmantek,項目名稱:chimera,代碼行數:51,代碼來源:HibernateUtil.java

示例4: getDatabaseMetaData

import javax.persistence.EntityManager; //導入方法依賴的package包/類
private DatabaseMetaData getDatabaseMetaData(EntityManager entityManager) throws SQLException {
    SessionImplementor sessionImplementor = entityManager.unwrap(SessionImplementor.class);
    DatabaseMetaData metaData = sessionImplementor.connection().getMetaData();
    entityManager.close();
    return metaData;
}
 
開發者ID:infobip,項目名稱:infobip-spring-data-jpa-querydsl,代碼行數:7,代碼來源:SimpleExtendedQueryDslJpaRepository.java

示例5: getSession

import javax.persistence.EntityManager; //導入方法依賴的package包/類
protected Session getSession(EntityManager em) {
	return em.unwrap(Session.class);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:4,代碼來源:HibernateJpaDialect.java

示例6: createQuery

import javax.persistence.EntityManager; //導入方法依賴的package包/類
private <X> TypedQuery<X> createQuery(EntityManager entityManager, Class<X> clazz, boolean pagedCount)
{
	StrQLBuilder oThis = this;
	while (oThis.unionParent != null)
	{
		log.warn("Warning: you are trying to execute a query over an auxiliar instance -used to build union union queries-. Use .endUnion() to remove this message.");
		oThis = oThis.unionParent;
	}
	String sql = oThis.build(pagedCount);
	Map<String, Object> parametersMap = oThis.getParametersMap();

	AbstractEntityManagerImpl abstractEntityManager = entityManager.unwrap(AbstractEntityManagerImpl.class);
	try
	{
		QueryTranslator translator = null;
		boolean fixJpqlCountQuery = !isNative && pagedCount;
		if (fixJpqlCountQuery)
		{
			translator = translator(sql, entityManager);
			sql = "select count(*) from (" + translator.getSQLString() + ") x";
		}
		Query q = createQuery(sql, abstractEntityManager, fixJpqlCountQuery);
		TypedQueryImpl<X> typedQuery = new TypedQueryImpl<X>(q, abstractEntityManager);
		if (fixJpqlCountQuery)
		{
			typedQuery.setPositionParameters(getPositionParametersMap(translator, parametersMap));
		}
		else
		{
			typedQuery.setParameters(parametersMap);
		}
		typedQuery.setAlias(oThis.select.getAliases());
		typedQuery.setTargetClass(clazz);

		return typedQuery;
	}
	catch (HibernateException he)
	{
		throw abstractEntityManager.convert(he);
	}
}
 
開發者ID:iaunzu,項目名稱:strqlbuilder,代碼行數:42,代碼來源:StrQLBuilder.java


注:本文中的javax.persistence.EntityManager.unwrap方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。