torrentpier-lts/library/Zend/Db/Sql/Predicate/Like.php

115 lines
2.3 KiB
PHP

<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
namespace Zend\Db\Sql\Predicate;
use Zend\Db\Sql\AbstractExpression;
class Like extends AbstractExpression implements PredicateInterface
{
/**
* @var string
*/
protected $specification = '%1$s LIKE %2$s';
/**
* @var string
*/
protected $identifier = '';
/**
* @var string
*/
protected $like = '';
/**
* @param string $identifier
* @param string $like
*/
public function __construct($identifier = null, $like = null)
{
if ($identifier) {
$this->setIdentifier($identifier);
}
if ($like) {
$this->setLike($like);
}
}
/**
* @param string $identifier
* @return self
*/
public function setIdentifier($identifier)
{
$this->identifier = $identifier;
return $this;
}
/**
* @return string
*/
public function getIdentifier()
{
return $this->identifier;
}
/**
* @param string $like
* @return self
*/
public function setLike($like)
{
$this->like = $like;
return $this;
}
/**
* @return string
*/
public function getLike()
{
return $this->like;
}
/**
* @param string $specification
* @return self
*/
public function setSpecification($specification)
{
$this->specification = $specification;
return $this;
}
/**
* @return string
*/
public function getSpecification()
{
return $this->specification;
}
/**
* @return array
*/
public function getExpressionData()
{
list($values[], $types[]) = $this->normalizeArgument($this->identifier, self::TYPE_IDENTIFIER);
list($values[], $types[]) = $this->normalizeArgument($this->like, self::TYPE_VALUE);
return array(
array(
$this->specification,
$values,
$types,
)
);
}
}