Overview

Namespaces

  • CzProject
    • SqlSchema

Classes

  • CzProject\SqlSchema\Column
  • CzProject\SqlSchema\ForeignKey
  • CzProject\SqlSchema\Index
  • CzProject\SqlSchema\IndexColumn
  • CzProject\SqlSchema\Schema
  • CzProject\SqlSchema\Table

Exceptions

  • CzProject\SqlSchema\DuplicateException
  • CzProject\SqlSchema\EmptyException
  • CzProject\SqlSchema\Exception
  • CzProject\SqlSchema\OutOfRangeException
  • CzProject\SqlSchema\StaticClassException
  • Overview
  • Namespace
  • Class
 1:  2:  3:  4:  5:  6:  7:  8:  9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77: 78: 79: 80: 81: 82: 83: 84: 85: 86: 87: 88: 89: 90: 91: 92: 93: 94: 95: 96: 97: 98: 99: 
<?php

    namespace CzProject\SqlSchema;


    class IndexColumn
    {
        const ASC = 'ASC';
        const DESC = 'DESC';

        /** @var string */
        private $name;

        /** @var string */
        private $order;

        /** @var int|NULL */
        private $length;


        /**
         * @param  string
         * @param  string
         * @param  int|NULL
         */
        public function __construct($name, $order = self::ASC, $length = NULL)
        {
            $this->setName($name);
            $this->setOrder($order);
            $this->setLength($length);
        }


        /**
         * @param  string
         * @return self
         */
        public function setName($name)
        {
            $this->name = $name;
            return $this;
        }


        /**
         * @return string
         */
        public function getName()
        {
            return $this->name;
        }


        /**
         * @param  string
         * @return self
         */
        public function setOrder($order)
        {
            $order = (string) $order;

            if ($order !== self::ASC && $order !== self::DESC) {
                throw new OutOfRangeException("Order type '$order' not found.");
            }

            $this->order = $order;
            return $this;
        }


        /**
         * @return string
         */
        public function getOrder()
        {
            return $this->order;
        }


        /**
         * @param  int|NULL
         * @return self
         */
        public function setLength($length)
        {
            $this->length = $length;
            return $this;
        }


        /**
         * @return int|NULL
         */
        public function getLength()
        {
            return $this->length;
        }
    }
czproject/sql-schema v2.0.1 API documentation API documentation generated by ApiGen