Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

सिद्धांत में LIMIT के साथ उपश्रेणी

उदाहरण के लिए LIMIT 1 . जोड़ने के लिए आप अपने स्वयं के सिंटैक्स को सिद्धांत में आसानी से जोड़ सकते हैं सबक्वेरी के लिए, जैसा कि कॉलिन ओ'डेल ने अपने ब्लॉग पर बताया

// AppBundle\DBAL\FirstFunction
<?php

use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\AST\Subselect;
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\Parser;
use Doctrine\ORM\Query\SqlWalker;

/**
 * FirstFunction ::=
 *     "FIRST" "(" Subselect ")"
 */
class FirstFunction extends FunctionNode
{
    /**
     * @var Subselect
     */
    private $subselect;

    /**
     * {@inheritdoc}
     */
    public function parse(Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->subselect = $parser->Subselect();
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }

    /**
     * {@inheritdoc}
     */
    public function getSql(SqlWalker $sqlWalker)
    {
        return '(' . $this->subselect->dispatch($sqlWalker) . ' LIMIT 1)';
    }
}
# app/config/config.yml
doctrine:
    # ...
    orm:
        # ...
        dql:
            string_functions:
                FIRST: AppBundle\DBAL\FirstFunction

इस प्रकार उपयोग करें:

$dqb->from('MyAppBundle:Foo', 'foo')
    ->leftJoin('foo.bar', 'bar', 'WITH', 'bar = FIRST(SELECT b FROM MyAppBundle:Bar b WHERE b.foo = foo AND b.published_date >= :now ORDER BY t.startDate)');


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. django . में DISTINCT ON

  2. ROR माइग्रेशन के दौरान कॉलम प्रकार को दिनांक से दिनांक समय में बदलें

  3. WampServer - mysqld.exe प्रारंभ नहीं हो सकता क्योंकि MSVCR120.dll अनुपलब्ध है

  4. मैं mysql के माध्यम से तालिका में सबसे लोकप्रिय शब्द कैसे प्राप्त कर सकता हूं?

  5. केकेपीएचपी - अंतिम क्वेरी चलाएं