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


PHP ResultSetMapping::addScalarResult方法代碼示例

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


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

示例1: findBestTaxonsByCatalogNumbers

 /**
  * @param Collection   $collection
  * @param array|string $catalogNumbers
  * @return array
  * @throws \Doctrine\ORM\NonUniqueResultException
  */
 public function findBestTaxonsByCatalogNumbers(Collection $collection, $catalogNumbers)
 {
     if (!is_array($catalogNumbers)) {
         $catalogNumbers = [$catalogNumbers];
     }
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('scientificname', 'scientificname');
     $rsm->addScalarResult('scientificnameauthorship', 'scientificnameauthorship');
     $rsm->addScalarResult('catalognumber', 'catalognumber');
     $nativeSqlTaxon = '
     WITH FirstIDentified AS (
        SELECT First_Value(t.taxonid) OVER (PARTITION BY catalognumber ORDER BY identificationverifstatus) First,
        t.taxonid, t.scientificname, t.scientificnameauthorship,
        s.catalognumber
        FROM Taxons t
        JOIN Determinations d ON t.taxonid = d.taxonid
        JOIN Specimens s on d.occurrenceid = s.occurrenceid
        WHERE s.collectioncode = :collectionCode AND
        s.catalognumber IN (:catalogNumbers)
     )
     SELECT catalognumber, scientificname, scientificnameauthorship FROM FirstIdentified
     WHERE taxonid = First
     ';
     $this->getEntityManager()->getConnection()->setFetchMode(\PDO::FETCH_ASSOC);
     $results = $this->getEntityManager()->getConnection()->executeQuery($nativeSqlTaxon, ['collectionCode' => $collection->getCollectioncode(), 'catalogNumbers' => $catalogNumbers], ['catalogNumbers' => Connection::PARAM_STR_ARRAY])->fetchAll();
     $formattedResult = [];
     if (count($results)) {
         foreach ($results as $values) {
             $formattedResult[$values['CATALOGNUMBER']] = Taxon::toString($values['SCIENTIFICNAME'], $values['SCIENTIFICNAMEAUTHORSHIP']);
         }
     }
     return $formattedResult;
 }
開發者ID:e-ReColNat,項目名稱:recolnat-diff,代碼行數:39,代碼來源:TaxonRepository.php

示例2: resultAction

 /**
  * @Route("/overallscore/{id}",name="result_report")
  * 
  */
 public function resultAction($id)
 {
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('amount', 'a');
     $rsm->addScalarResult('total', 't');
     $em = $this->getDoctrine()->getManager();
     $verbalr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'verbal', $rsm);
     $mathr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'mathematical', $rsm);
     $spatialr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'spatial', $rsm);
     $visualr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'visualization', $rsm);
     $classifyr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'classification', $rsm);
     $logicr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'logic', $rsm);
     $patternr = $em->getRepository('SetupBundle:QuizQuestion')->findScoreByType($id, 'pattern recognition', $rsm);
     $verbal = implode(",", $verbalr[0]);
     $math = implode(",", $mathr[0]);
     $spatial = implode(",", $spatialr[0]);
     $visual = implode(",", $visualr[0]);
     $classify = implode(",", $classifyr[0]);
     $logic = implode(",", $logicr[0]);
     $pattern = implode(",", $patternr[0]);
     if (!$verbalr || !$mathr || !$visualr || !$classifyr || !$patternr || !$logicr || !$spatialr) {
         throw $this->createNotFoundException('No Data found for Person');
     }
     return $this->render('ReportBundle::user.html.twig', array('verbal' => $verbal, 'math' => $math, 'visual' => $visual, 'classify' => $classify, 'pattern' => $pattern, 'logic' => $logic, 'spatial' => $spatial, 'name' => 'User Result'));
 }
開發者ID:jflash49,項目名稱:capstone,代碼行數:29,代碼來源:ReportController.php

示例3: __construct

 public function __construct(\Doctrine\ORM\EntityManagerInterface $entityManager)
 {
     parent::__construct($entityManager);
     $resultSetMapping = new ResultSetMapping();
     $resultSetMapping->addScalarResult('ID', 'id');
     $resultSetMapping->addScalarResult('Name', 'name');
     $this->setResultMapping($resultSetMapping);
 }
開發者ID:TiiToo,項目名稱:GammuBundle,代碼行數:8,代碼來源:PhoneBookGroupManager.php

示例4: top20TableSizes

 public function top20TableSizes()
 {
     $sql = "SELECT nspname || '.' || relname AS relation,\n                  pg_size_pretty(pg_relation_size(C.oid)) AS size\n                FROM pg_class C\n                LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace)\n                WHERE nspname NOT IN ('pg_catalog', 'information_schema')\n                  AND C.relkind <> 'i'\n                  AND nspname !~ '^pg_toast'\n                  AND nspname || '.' || relname != 'public.spatial_ref_sys'\n                ORDER BY pg_relation_size(C.oid) DESC\n                LIMIT 20";
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('relation', 'relation');
     $rsm->addScalarResult('size', 'size');
     $query = $this->em->createNativeQuery($sql, $rsm);
     return $query->getResult();
 }
開發者ID:godentarek,項目名稱:whathood,代碼行數:9,代碼來源:PostgresMapper.php

示例5: __construct

 public function __construct(\Doctrine\ORM\EntityManagerInterface $entityManager)
 {
     parent::__construct($entityManager);
     $resultSetMapping = new ResultSetMapping();
     $resultSetMapping->addScalarResult('DestinationNumber', 'receiver');
     $resultSetMapping->addScalarResult('TextDecoded', 'message');
     $resultSetMapping->addScalarResult('Status', 'status');
     $resultSetMapping->addScalarResult('SenderID', 'phone');
     $this->setResultMapping($resultSetMapping);
 }
開發者ID:TiiToo,項目名稱:GammuBundle,代碼行數:10,代碼來源:SentItemsManager.php

示例6: indexAction

 /**
  * Lists all Empleado entities.
  *
  * @Route("/", name="admin_empleado")
  * @Method("GET")
  * @Template()
  */
 public function indexAction()
 {
     $entity = new Empleado();
     $form = $this->createCreateForm($entity);
     $rsm = new ResultSetMapping();
     $em = $this->getDoctrine()->getManager();
     $sql = "select per.nombres as pnombre, per.apellidos as papellido,  " . "per.direccion as direccion, per.telefono as tel, per.email as email, emp.id as idemp, emp.cargo as cargo, emp.foto as foto,  emp.estado as estado " . "from empleado emp inner join persona per on emp.persona = per.id where emp.estado=true  order by per.apellidos";
     $rsm->addScalarResult('idemp', 'idemp');
     $rsm->addScalarResult('pnombre', 'pnombre');
     //$rsm->addScalarResult('snombre','snombre');
     $rsm->addScalarResult('papellido', 'papellido');
     //$rsm->addScalarResult('sapellido','sapellido');
     //$rsm->addScalarResult('casada','casada');
     $rsm->addScalarResult('direccion', 'direccion');
     $rsm->addScalarResult('tel', 'tel');
     $rsm->addScalarResult('email', 'email');
     $rsm->addScalarResult('cargo', 'cargo');
     $rsm->addScalarResult('foto', 'foto');
     //$rsm->addScalarResult('sucursal','sucursal');
     $rsm->addScalarResult('estado', 'estado');
     $empleados = $em->createNativeQuery($sql, $rsm)->getResult();
     $usuario = $this->get('security.token_storage')->getToken()->getUser();
     $foto = $usuario->getPersona()->getEmpleado()[0]->getFoto();
     return array('empleados' => $empleados, 'entity' => $entity, 'form' => $form->createView(), 'foto' => $foto);
 }
開發者ID:samrodriguez,項目名稱:plusbella,代碼行數:32,代碼來源:EmpleadoController.php

示例7: relatorioWmiDinamico

 /**
  *
  * Relatório de Configurações das Classes WMI Dinâmico Detalhes
  *
  */
 public function relatorioWmiDinamico($property, $dataInicio, $dataFim)
 {
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('nm_rede', 'nm_rede');
     $rsm->addScalarResult('dt_hr_ult_acesso', 'dt_hr_ult_acesso');
     $rsm->addScalarResult('id_computador', 'id_computador');
     $rsm->addScalarResult('nm_computador', 'nm_computador');
     $rsm->addScalarResult('te_node_address', 'te_node_address');
     $rsm->addScalarResult('te_ip_computador', 'te_ip_computador');
     $rsm->addScalarResult('te_ip_rede', 'te_ip_rede');
     $rsm->addScalarResult('nm_rede', 'nm_rede');
     $sql = 'SELECT c.id_computador, c.nm_computador, c.te_node_address, c.te_ip_computador, r.te_ip_rede, r.nm_rede, c.dt_hr_ult_acesso, ';
     foreach ($property as $elm) {
         $sql = $sql . "(CASE WHEN rc.{$elm} IS NOT NULL\n            THEN rc.{$elm}\n            ELSE 'Não identificado'\n            END) as {$elm}, ";
         $rsm->addScalarResult($elm, $elm);
     }
     $size = strlen($sql);
     $sql = substr($sql, 0, $size - 2);
     $sql = $sql . " FROM relatorio_coleta rc\n        INNER JOIN computador c ON rc.id_computador = c.id_computador\n        INNER JOIN rede r ON r.id_rede = c.id_rede\n        WHERE (c.ativo IS NULL or c.ativo = 't')";
     if (!empty($dataInicio)) {
         $sql .= " AND c.dt_hr_ult_acesso >= '{$dataInicio} 00:00:00'";
     }
     if (!empty($dataFim)) {
         $sql .= " AND c.dt_hr_ult_acesso <= '{$dataFim} 23:59:59'";
     }
     $result = $this->getEntityManager()->createNativeQuery($sql, $rsm)->execute();
     return $result;
 }
開發者ID:adrianomastro,項目名稱:cacic,代碼行數:33,代碼來源:ClassPropertyRepository.php

示例8: findEntityUsersRight

 public function findEntityUsersRight($entity, $em)
 {
     $entityName = get_class($entity);
     $entityId = $entity->getId();
     $tables = array('acl_classes' => $this->container->getParameter('security.acl.dbal.class_table_name'), 'acl_security_identities' => $this->container->getParameter('security.acl.dbal.sid_table_name'), 'acl_object_identities' => $this->container->getParameter('security.acl.dbal.oid_table_name'), 'acl_object_ancestors' => $this->container->getParameter('security.acl.dbal.oid_ancestors_table_name'), 'acl_entries' => $this->container->getParameter('security.acl.dbal.entry_table_name'));
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('identifier', 'identifier');
     $rsm->addScalarResult('mask', 'mask');
     $query = $em->createNativeQuery('SELECT SI.IDENTIFIER,E.MASK ' . 'FROM ' . $tables['acl_classes'] . ' C ' . 'JOIN ' . $tables['acl_object_identities'] . ' OI ON C.ID = OI.CLASS_ID ' . 'JOIN ' . $tables['acl_entries'] . ' E ON E.CLASS_ID = C.ID AND E.OBJECT_IDENTITY_ID = OI.ID ' . 'JOIN ' . $tables['acl_security_identities'] . ' SI ON SI.ID = E.SECURITY_IDENTITY_ID ' . 'WHERE C.CLASS_TYPE = ? ' . 'AND OI.OBJECT_IDENTIFIER = ? ' . 'ORDER BY SI.IDENTIFIER', $rsm);
     $query->setParameter(1, $entityName);
     $query->setParameter(2, $entityId);
     $result = array();
     $users = array();
     $previousIdentifier = null;
     foreach ($query->getResult() as $i => $row) {
         if (strpos($row['identifier'], '-') === FALSE) {
             $login = $row['identifier'];
             $result[$login]['type'] = 'role';
         } else {
             $login = substr($row['identifier'], strpos($row['identifier'], '-') + 1);
             $result[$login]['type'] = 'user';
         }
         if (!array_key_exists($login, $result)) {
             $result[$login] = array();
         }
         $result[$login]['masks'][] = $row['mask'];
         $result[$login]['user'] = array();
         $result[$login]['login'] = $login;
         // $result[$login]['mask']      = $row['mask'];
         $result[$login]['rights'][] = 'role.mask.' . $row['mask'];
         $result[$login]['descriptions'][] = 'role.rightdescription.' . $row['mask'];
         $users[] = $result[$login]['login'];
     }
     if ($users != null) {
         $qb = $em->createQueryBuilder();
         $qb->add('select', 'u.id,u.username,u.firstName,u.lastName,u.email,u.locked')->add('from', 'LowbiSystemBundle:User u');
         $qb->add('where', $qb->expr()->in('u.username', '?1'));
         $qb->setParameter(1, $users);
         $query = $qb->getQuery();
         $userresult = $query->getResult();
         $usersArray = array();
         foreach ($userresult as $item) {
             $usersArray[$item['username']] = $item;
         }
         foreach ($result as $key => $item) {
             if ($result[$key]['type'] == 'user') {
                 $result[$key]['user'] = $usersArray[$item['login']];
             }
         }
         return $result;
     } else {
         return null;
     }
 }
開發者ID:r4cker,項目名稱:lowbi,代碼行數:54,代碼來源:Permissions.php

示例9: testHydrateScalarResults

 /**
  * @group DDC-407
  */
 public function testHydrateScalarResults()
 {
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('foo1', 'foo');
     $rsm->addScalarResult('bar2', 'bar');
     $rsm->addScalarResult('baz3', 'baz');
     $resultSet = array(array('foo1' => 'A', 'bar2' => 'B', 'baz3' => 'C'));
     $stmt = new HydratorMockStatement($resultSet);
     $hydrator = new \Doctrine\ORM\Internal\Hydration\ScalarHydrator($this->_em);
     $result = $hydrator->hydrateAll($stmt, $rsm);
 }
開發者ID:jacques-sounvi,項目名稱:addressbook,代碼行數:14,代碼來源:ScalarHydratorTest.php

示例10: __construct

 public function __construct(\Doctrine\ORM\EntityManagerInterface $entityManager)
 {
     parent::__construct($entityManager);
     $resultSetMapping = new ResultSetMapping();
     $resultSetMapping->addScalarResult('ID', 'id');
     $resultSetMapping->addScalarResult('SenderNumber', 'sender');
     $resultSetMapping->addScalarResult('TextDecoded', 'message');
     $resultSetMapping->addScalarResult('Processed', 'processed');
     $resultSetMapping->addScalarResult('RecipientID', 'phone');
     $this->setResultMapping($resultSetMapping);
 }
開發者ID:TiiToo,項目名稱:GammuBundle,代碼行數:11,代碼來源:InboxManager.php

示例11: getJournals

    private function getJournals()
    {
        $sql = <<<SQL
        SELECT id,footer_text FROM journal WHERE journal.footer_text is not null
SQL;
        $rsm = new ResultSetMapping();
        $rsm->addScalarResult('id', 'id');
        $rsm->addScalarResult('footer_text', 'text');
        $query = $this->em->createNativeQuery($sql, $rsm);
        return $query->getResult();
    }
開發者ID:ojs,項目名稱:ojs,代碼行數:11,代碼來源:JournalFooterTextNormalizeCommand.php

示例12: testFindByNativeCQL

 public function testFindByNativeCQL()
 {
     $em = $this->getEntityManager();
     $rsm = new ResultSetMapping();
     $rsm->addScalarResult('name', 'name');
     $rsm->addScalarResult('price', 'price');
     $query = $em->createNativeQuery('SELECT * FROM product WHERE name = ?', $rsm);
     $query->setParameter(1, 'prod2');
     $products = $query->getResult();
     $this->assertNotEmpty($products);
     $this->assertInternalType('array', $products[0]);
 }
開發者ID:balalaikaboy,項目名稱:CassandraPDO4Doctrine,代碼行數:12,代碼來源:CP4DTest.php

示例13: contentiousPointsByCreateEventId

 /**
  *
  *   get contentious points by the create event
  *
  **/
 public function contentiousPointsByCreateEventId($createEventId)
 {
     if (empty($createEventId)) {
         throw new \InvalidArgumentException('createEventId may not be empty');
     }
     $sql = "SELECT ST_X(point) as x, ST_Y(point) as y FROM contentious_point WHERE create_event_id = :createEventId";
     $rsm = new \Doctrine\ORM\Query\ResultSetMapping();
     $rsm->addScalarResult('x', 'x');
     $rsm->addScalarResult('y', 'y');
     $query = $this->em->createNativeQuery($sql, $rsm);
     $query->setParameter('createEventId', $createEventId);
     return $query->getResult();
 }
開發者ID:KGalley,項目名稱:whathood,代碼行數:18,代碼來源:ContentiousPointMapper.php

示例14: getBySupportAddressAndCustomerDomainCriteria

 /**
  * Retrieves BranchEmailConfiguration using $supportAddress and $customerDomain as Criteria
  *
  * @param $supportAddress
  * @param $customerDomain
  * @return int|null
  * @throws \Doctrine\ORM\NonUniqueResultException
  */
 public function getBySupportAddressAndCustomerDomainCriteria($supportAddress, $customerDomain)
 {
     $customerDomainRegExp = "[[:<:]]" . $customerDomain . "[[:>:]]";
     $rsm = new ResultSetMapping();
     $rsm->addEntityResult('DiamanteDeskBundle:BranchEmailConfiguration', 'j');
     $rsm->addScalarResult('branch_id', 'branch_id');
     $rsm->addScalarResult('criteria', 'criteria');
     $result = $this->getEntityManager()->createNativeQuery("\n            SELECT j.branch_id as branch_id,\n               (j.support_address = :supportAddress AND\n                 j.customer_domains REGEXP :customerDomainRegExp) * 3 +\n               (j.support_address = :supportAddress AND\n                 j.customer_domains = '') * 2 +\n               (j.support_address = '' AND\n                 j.customer_domains REGEXP :customerDomainRegExp) * 1\n            AS criteria\n            FROM diamante_branch_email_configuration j ORDER BY criteria DESC LIMIT 1\n        ", $rsm)->setParameter('supportAddress', $supportAddress)->setParameter('customerDomainRegExp', $customerDomainRegExp)->getOneOrNullResult();
     if ($result['criteria']) {
         return $result['branch_id'];
     } else {
         return null;
     }
 }
開發者ID:northdakota,項目名稱:diamantedesk-application,代碼行數:22,代碼來源:DoctrineBranchEmailConfigurationRepository.php

示例15: testSkipUnknownColumns

 /**
  * @group DDC-644
  */
 public function testSkipUnknownColumns()
 {
     $rsm = new ResultSetMapping();
     $rsm->addEntityResult('Doctrine\\Tests\\Models\\CMS\\CmsUser', 'u');
     $rsm->addFieldResult('u', 'u__id', 'id');
     $rsm->addFieldResult('u', 'u__name', 'name');
     $rsm->addScalarResult('foo1', 'foo');
     $rsm->addScalarResult('bar2', 'bar');
     $rsm->addScalarResult('baz3', 'baz');
     $resultSet = array(array('u__id' => '1', 'u__name' => 'romanb', 'foo1' => 'A', 'bar2' => 'B', 'baz3' => 'C', 'foo' => 'bar'));
     $stmt = new HydratorMockStatement($resultSet);
     $hydrator = new \Doctrine\ORM\Internal\Hydration\ScalarHydrator($this->_em);
     $result = $hydrator->hydrateAll($stmt, $rsm);
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:17,代碼來源:ScalarHydratorTest.php


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