cassell/Parm

View on GitHub
src/Binding/Binding.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace Parm\Binding;

class Binding implements SQLString
{
    /**
     * The field/column to filter on
     * @var string
     */
    public $field;

    /**
     * The value to filter the field/column on
     * @var string
     */
    public $value;

    /**
     * The operator for the filtering
     * @var string
     */
    public $operator;

    /**
     * Create a new Binding from the field(column_name), operator(=,!=,etc), and value.
     * @param string $field
     * @param string $operator
     * @param string $value
     */
    public function __construct($field, $operator, $value)
    {
        $this->field = $field;
        $this->value = $value;
        $this->operator = $operator;
    }

    /**
     * Return the SQL String
     *
     * @param  \Parm\DataAccessObjectFactory $factory
     * @return string
     */
    public function getSQL(\Parm\DataAccessObjectFactory $factory)
    {
        if ($this->value === null) {
            return $this->field . " " . $this->operator . " NULL";

        } elseif (is_int($this->value)) {
            return $this->field . " " . $this->operator . " " . $this->value;
        } else {
            return $this->field . " " . $this->operator . " " . $factory->escapeString($this->value);
        }

    }

}