Code Duplication    Length = 23-24 lines in 2 locations

framework/db/DBCore.php 2 locations

@@ 794-816 (lines=23) @@
791
     * @return array Selected record with table names as keys or NULL if no
792
     *               data selected.
793
     */
794
    public static function selectSingleRecord($query, $types = '', $params = [])
795
    {
796
        if (!Tools::isInstanceOf($query, new DBPreparedQuery())) {
797
            $dbQuery = new DBPreparedQuery($query, $types, $params);
798
        } else {
799
            $dbQuery = $query;
800
        }
801
        $stmt = $dbQuery->go();
802
803
        if ($stmt !== false) {
804
            $record = null;
805
            if ($stmt->num_rows === 1) {
806
                $record = self::bindResults($stmt);
807
            }
808
            $stmt->close();
809
810
            if (is_null($record)) {
811
                throw new DBCoreException('No one or more than one records selected.');
812
            }
813
814
            return $record;
815
        }
816
    }
817
818
    /**
819
     * Executes SQL query with single record and value result and return this value.
@@ 830-853 (lines=24) @@
827
     *
828
     * @return mixed
829
     */
830
    public static function selectSingleValue($query, $types = '', $params = [])
831
    {
832
        if (!Tools::isInstanceOf($query, new DBPreparedQuery())) {
833
            $dbQuery = new DBPreparedQuery($query, $types, $params);
834
        } else {
835
            $dbQuery = $query;
836
        }
837
        $stmt = $dbQuery->go();
838
839
        if ($stmt !== false) {
840
            $value = null;
841
            if ($stmt->num_rows === 1) {
842
                $stmt->bind_result($value);
843
                $stmt->fetch();
844
            }
845
            $stmt->close();
846
847
            if (is_null($value)) {
848
                throw new DBCoreException('No one or more than one records selected.');
849
            }
850
851
            return $value;
852
        }
853
    }
854
855
    /**
856
     * Calls DBCore magic methods like: