當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Connection::quote方法代碼示例

本文整理匯總了PHP中Doctrine\DBAL\Connection::quote方法的典型用法代碼示例。如果您正苦於以下問題:PHP Connection::quote方法的具體用法?PHP Connection::quote怎麽用?PHP Connection::quote使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Doctrine\DBAL\Connection的用法示例。


在下文中一共展示了Connection::quote方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: doSetAll

 /**
  * {@inheritDoc}
  */
 protected function doSetAll(array $values)
 {
     $this->runSQL('DELETE FROM `' . $this->tableName . '`');
     $rows = array();
     foreach ($values as $key => $value) {
         $this->runSQL('INSERT INTO ' . $this->tableName . ' (`key`, `value`) VALUES (' . $this->connection->quote($key) . ',' . $this->connection->quote(json_encode($value)) . ');');
     }
 }
開發者ID:phecho,項目名稱:gitonomy,代碼行數:11,代碼來源:MysqlConfig.php

示例2: postUpdate

 public function postUpdate()
 {
     $em = $this->container->get('doctrine.orm.entity_manager');
     $process = false;
     if (in_array('claro_forum_subject_temp', $this->conn->getSchemaManager()->listTableNames())) {
         $columns = $this->conn->getSchemaManager()->listTableColumns('claro_forum_subject_temp');
         foreach ($columns as $column) {
             if ($column->getName() === 'forum_id') {
                 $process = true;
                 break;
             }
         }
     }
     if ($process) {
         $this->log('restoring the subjects...');
         $forums = $em->getRepository('ClarolineForumBundle:Forum')->findAll();
         $sql = 'SELECT * FROM claro_forum_subject_temp WHERE forum_id = :forumId';
         $stmt = $this->conn->prepare($sql);
         foreach ($forums as $forum) {
             $category = new Category();
             $category->setName($forum->getResourceNode()->getName());
             $category->setForum($forum);
             $em->persist($category);
             $em->flush();
             $stmt->bindValue('forumId', $forum->getId());
             $stmt->execute();
             foreach ($stmt->fetchAll() as $rowsSubject) {
                 $this->conn->query("INSERT INTO claro_forum_subject VALUES (\n                        {$rowsSubject['id']},\n                        {$category->getId()},\n                        {$rowsSubject['user_id']},\n                        {$this->conn->quote($rowsSubject['title'])},\n                        '{$rowsSubject['created']}',\n                        '{$rowsSubject['updated']}',\n                        false\n                    )");
             }
         }
         $this->log('restoring the messages...');
         $this->conn->query('INSERT IGNORE INTO claro_forum_message SELECT * FROM claro_forum_message_temp');
         $this->conn->query('DROP TABLE claro_forum_message_temp');
         $this->conn->query('DROP TABLE claro_forum_subject_temp');
         $this->conn->query('DROP TABLE claro_forum_options');
     } else {
         $this->log('categories already added');
     }
     $widget = $em->getRepository('ClarolineCoreBundle:Widget\\Widget')->findBy(array('name' => 'claroline_forum_widget'));
     if (!$widget) {
         $this->log('adding the forum widget...');
         $plugin = $em->getRepository('ClarolineCoreBundle:Plugin')->findOneBy(array('vendorName' => 'Claroline', 'bundleName' => 'ForumBundle'));
         $widget = new Widget();
         $widget->setName('claroline_forum_widget');
         $widget->setDisplayableInDesktop(true);
         $widget->setDisplayableInWorkspace(true);
         $widget->setConfigurable(false);
         $widget->setExportable(false);
         $widget->setIcon('none');
         $widget->setPlugin($plugin);
         $em->persist($widget);
         $plugin->setHasOptions(true);
         $em->persist($widget);
         $em->flush();
     } else {
         $this->log('forum widget already added');
     }
 }
開發者ID:claroline,項目名稱:distribution,代碼行數:58,代碼來源:Updater020200.php

示例3: generateSql

 public function generateSql($routeName, $type, array $state, array $title, array $description, array $alias, array $path, $parentRouteName = null, $template = null)
 {
     $sql = [];
     $currentDate = (new \DateTime())->format('y-m-d H:i:s');
     $sql[] = sprintf("SELECT @parentId:=id FROM `%s` WHERE `route_name` = '%s' LIMIT 1;", self::STRUCTURE_TABLE_NAME, $this->connection->quote($parentRouteName));
     $sql[] = sprintf("INSERT INTO `%s`\n            (\n                `parent_id`,\n                `created_at`,\n                `updated_at`,\n                `title`,\n                `description`,\n                `type`,\n                `alias`,\n                `path`,\n                `state`,\n                `template`,\n                `route_name`\n              )\n            VALUES (\n                @parentId,\n                '%s',\n                '%s',\n                '%s',\n                '%s',\n                '%s',\n                '%s',\n                '%s',\n                '%d',\n                '%s',\n                '%s'\n            )\n            ON DUPLICATE KEY UPDATE\n                `parent_id`=VALUES(`parent_id`),\n                `updated_at`=VALUES(`updated_at`),\n                `title`=VALUES(`title`),\n                `description`=VALUES(`description`),\n                `type`=VALUES(`type`),\n                `alias`=VALUES(`alias`),\n                `path`=VALUES(`path`),\n                `state`=VALUES(`state`),\n                `template`=VALUES(`template`)\n            ;", self::STRUCTURE_TABLE_NAME, $currentDate, $currentDate, $this->connection->quote($title[$this->defaultLocale]), $this->connection->quote($description[$this->defaultLocale]), $type, $this->connection->quote($alias[$this->defaultLocale]), $this->connection->quote($path[$this->defaultLocale]), (bool) $state[$this->defaultLocale] ? 1 : 0, $this->connection->quote($template), $this->connection->quote($routeName));
     $sql[] = sprintf("SELECT @structureId := id FROM `%s` WHERE route_name = '%s';", self::STRUCTURE_TABLE_NAME, $this->connection->quote($routeName));
     return implode("\n", $sql);
 }
開發者ID:octava,項目名稱:cms,代碼行數:9,代碼來源:StructureMigration.php

示例4: getBindVarValue

 /**
  * Changes a value to a specific type.
  *
  * The original implementation of this method
  * had some vestiges of support for type options
  * (like a regular expression pattern for the regexp
  * type) . This seems to have long been unsupported
  * so now all bits of the type after <code>:</code>
  * are squashed.
  *
  * @param  mixed  $value value to bind
  * @param  string $type  type of value
  * @return mixed  modified value
  */
 public function getBindVarValue($value, $type)
 {
     if (false !== strpos($type, ':')) {
         $type = strstr($type, ':', true);
     }
     switch ($type) {
         case 'csv':
         case 'passthru':
             return $value;
             break;
         case 'floatval':
             return is_numeric($value) ? $value : 0;
             break;
         case 'integer':
             return (int) $value;
             break;
         case 'currency':
         case 'date':
         case 'string':
             return $this->conn->quote($value);
             break;
         case 'noquotestring':
             return $this->prepareInput($value);
         case 'regexp':
             return $this->prepareInput(preg_quote($value));
     }
     throw new RuntimeException(sprintf('Type %s does not exist', $type));
 }
開發者ID:zenmagick,項目名稱:zenmagick,代碼行數:42,代碼來源:QueryFactory.php

示例5: in

 /**
  * Returns the SQL to check if a value is one in a set of
  * given values..
  *
  * in() accepts an arbitrary number of parameters. The first parameter
  * must always specify the value that should be matched against. Successive
  * parameters must contain a logical expression or an array with logical
  * expressions.  These expressions will be matched against the first
  * parameter.
  *
  * Example:
  * <code>
  * $q->select( '*' )->from( 'table' )
  *                  ->where( $q->expr->in( 'id', 1, 2, 3 ) );
  * </code>
  *
  * @throws \eZ\Publish\Core\Persistence\Database\QueryException if called with less than two
  *         parameters.
  * @throws \eZ\Publish\Core\Persistence\Database\QueryException if the 2nd parameter is an
  *         empty array.
  *
  * @param string $column the value that should be matched against
  * @param string|array(string) $... values that will be matched against $column
  *
  * @return string logical expression
  */
 public function in($column)
 {
     $args = func_get_args();
     if (count($args) < 2) {
         throw new QueryException('Expected two or more parameters to in()');
     }
     if (is_array($args[1])) {
         $values = array_values($args[1]);
     } else {
         $values = array_slice($args, 1);
     }
     // Special handling of sub selects to avoid double braces
     if (count($values) === 1 && $values[0] instanceof SubselectDoctrineQuery) {
         return "{$column} IN " . $values[0]->getQuery();
     }
     if (count($values) == 0) {
         throw new QueryException('At least one element is required as value.');
     }
     foreach ($values as $key => $value) {
         switch (true) {
             case $value instanceof SubselectDoctrineQuery:
                 $values[$key] = $value->getQuery();
                 break;
             case is_int($value):
             case is_float($value):
                 $values[$key] = (string) $value;
                 break;
             default:
                 $values[$key] = $this->connection->quote($value);
         }
     }
     return "{$column} IN ( " . implode(', ', $values) . ' )';
 }
開發者ID:ezsystems,項目名稱:ezpublish-kernel,代碼行數:59,代碼來源:DoctrineExpression.php

示例6: buildQueryFromKeywords

 /**
  * Generates a single query builder from the provided keywords array.
  *
  * @param Keyword[] $keywords
  * @param $tables
  * @return QueryBuilder
  */
 private function buildQueryFromKeywords($keywords, $tables)
 {
     $keywordSelection = [];
     foreach ($keywords as $match) {
         $keywordSelection[] = 'SELECT ' . $match->getRelevance() . ' as relevance, ' . $this->connection->quote($match->getTerm()) . ' as term, ' . $match->getId() . ' as keywordID';
     }
     $keywordSelection = implode("\n             UNION ALL ", $keywordSelection);
     $tablesSql = [];
     foreach ($tables as $table) {
         $query = $this->connection->createQueryBuilder();
         $alias = 'st' . $table['tableID'];
         $query->select(['MAX(sf.relevance * sm.relevance) as relevance', 'sm.keywordID']);
         $query->from('(' . $keywordSelection . ')', 'sm');
         $query->innerJoin('sm', 's_search_index', 'si', 'sm.keywordID = si.keywordID');
         $query->innerJoin('si', 's_search_fields', 'sf', 'si.fieldID = sf.id AND sf.relevance != 0 AND sf.tableID = ' . $table['tableID']);
         $query->groupBy('articleID')->addGroupBy('sm.term')->addGroupBy('sf.id');
         if (!empty($table['referenz_table'])) {
             $query->addSelect($alias . '.articleID as articleID');
             $query->innerJoin('si', $table['referenz_table'], $alias, 'si.elementID = ' . $alias . '.' . $table['foreign_key']);
         } elseif (!empty($table['foreign_key'])) {
             $query->addSelect($alias . '.id as articleID');
             $query->innerJoin('si', 's_articles', $alias, 'si.elementID = ' . $alias . '.' . $table['foreign_key']);
         } else {
             $query->addSelect('si.elementID as articleID');
         }
         $tablesSql[] = $query->getSQL();
     }
     $tablesSql = "\n" . implode("\n     UNION ALL\n", $tablesSql);
     $subQuery = $this->connection->createQueryBuilder();
     $subQuery->select(['srd.articleID', 'SUM(srd.relevance) as relevance']);
     $subQuery->from("(" . $tablesSql . ')', 'srd')->groupBy('srd.articleID')->setMaxResults(5000);
     $query = $this->connection->createQueryBuilder();
     $query->from("(" . $subQuery->getSQL() . ')', 'sr')->innerJoin('sr', 's_articles', 'a', 'a.id = sr.articleID');
     return $query;
 }
開發者ID:GerDner,項目名稱:luck-docker,代碼行數:42,代碼來源:SearchTermQueryBuilder.php

示例7: sqlDownData

 /**
  * Revert data to the previous version.
  */
 public function sqlDownData()
 {
     // Map columns to custom fields.
     $colmap = array();
     foreach ($this->fieldmap as $field => $col) {
         $colmap[$col] = $field;
     }
     // Test that the v2 columns actually exist.
     $existingCols = $this->conn->getSchemaManager()->listTableColumns($this->usersTable);
     $existingColnames = array_map(function ($col) {
         return $col->getName();
     }, $existingCols);
     foreach ($this->fieldmap as $col) {
         if (!in_array($col, $existingColnames)) {
             throw new \RuntimeException('Cannot migrate down because current schema is not v2. (Missing column "' . $this->usersTable . '.' . $col . '").');
         }
     }
     // Get user columns to revert back to custom fields.
     $userData = $this->conn->fetchAll('SELECT id AS user_id, ' . implode(', ', $this->fieldmap) . ' FROM ' . $this->conn->quoteIdentifier($this->usersTable));
     $queries = array();
     foreach ($userData as $row) {
         foreach ($this->fieldmap as $col) {
             if ($row[$col] !== null) {
                 $queries[] = 'INSERT INTO ' . $this->conn->quoteIdentifier($this->userCustomFieldsTable) . ' (user_id, attribute, value) VALUES' . ' (' . $this->conn->quote($row['user_id'], Type::INTEGER) . ', ' . $this->conn->quote($colmap[$col], Type::STRING) . ', ' . $this->conn->quote($row[$col], Type::STRING) . ')';
             }
         }
     }
     return $queries;
 }
開發者ID:dactivo,項目名稱:silex-simpleuser,代碼行數:32,代碼來源:MigrateV1ToV2.php

示例8: quoteValue

 /**
  * @param mixed $value
  * @param Type  $type
  *
  * @return string
  */
 protected function quoteValue($value, Type $type)
 {
     // Don't quote numbers as some don't follow standards for casting
     if (is_scalar($value) && ctype_digit((string) $value)) {
         return (string) $value;
     }
     return $this->connection->quote($value, $type->getBindingType());
 }
開發者ID:rollerworks,項目名稱:search-doctrine-dbal,代碼行數:14,代碼來源:AbstractQueryPlatform.php

示例9: getRawSql

 public function getRawSql()
 {
     $sql = $this->getSql();
     foreach ($this->qb->getParameters() as $key => $value) {
         $sql = str_replace(':' . $key, $this->connection->quote($value), $sql);
     }
     return $sql;
 }
開發者ID:eddmash,項目名稱:powerorm,代碼行數:8,代碼來源:Queryset.php

示例10: update

 /**
  * Update object
  *
  * @param StorableInterface $obj
  * @param string            $type
  *
  * @return void
  */
 protected function update(StorableInterface $obj, $type)
 {
     $qb = $this->con->createQueryBuilder()->update($this->tables[$type])->where('id = :id')->setParameter('id', $obj->getId(), \PDO::PARAM_INT);
     foreach ($obj->getStorableData() as $name => $value) {
         $qb->set($name, $this->con->quote($value));
     }
     return $qb->execute();
 }
開發者ID:albancrommer,項目名稱:acmephpc,代碼行數:16,代碼來源:DoctrineDbal.php

示例11: lookupRange

 public function lookupRange(&$escapedField, &$rawValue, &$negate)
 {
     if (!is_array($rawValue) || count($rawValue) !== 2) {
         throw new \InvalidArgumentException("value for RANGE lookup must me array with two elements");
     }
     $rawValue = Expr($this->db->quote($rawValue[0]) . ' AND ' . $this->db->quote($rawValue[1]));
     return 'BETWEEN %s';
 }
開發者ID:buldezir,項目名稱:dja_orm,代碼行數:8,代碼來源:LookupAbstract.php

示例12: prepareTranslatedComponents

 /**
  * Creates a left join list for translations
  * on used query components
  *
  * @todo: make it cleaner
  * @return string
  */
 private function prepareTranslatedComponents()
 {
     $q = $this->getQuery();
     $locale = $q->getHint(TranslatableListener::HINT_TRANSLATABLE_LOCALE);
     if (!$locale) {
         // use from listener
         $locale = $this->listener->getListenerLocale();
     }
     $defaultLocale = $this->listener->getDefaultLocale();
     if ($locale === $defaultLocale && !$this->listener->getPersistDefaultLocaleTranslation()) {
         // Skip preparation as there's no need to translate anything
         return;
     }
     $em = $this->getEntityManager();
     $ea = new TranslatableEventAdapter();
     $ea->setEntityManager($em);
     $joinStrategy = $q->getHint(TranslatableListener::HINT_INNER_JOIN) ? 'INNER' : 'LEFT';
     foreach ($this->translatedComponents as $dqlAlias => $comp) {
         $meta = $comp['metadata'];
         $config = $this->listener->getConfiguration($em, $meta->name);
         $transClass = $this->listener->getTranslationClass($ea, $meta->name);
         $transMeta = $em->getClassMetadata($transClass);
         $transTable = $transMeta->getQuotedTableName($this->platform);
         foreach ($config['fields'] as $field) {
             $compTblAlias = $this->walkIdentificationVariable($dqlAlias, $field);
             $tblAlias = $this->getSQLTableAlias('trans' . $compTblAlias . $field);
             $sql = " {$joinStrategy} JOIN " . $transTable . ' ' . $tblAlias;
             $sql .= ' ON ' . $tblAlias . '.' . $transMeta->getQuotedColumnName('locale', $this->platform) . ' = ' . $this->conn->quote($locale);
             $sql .= ' AND ' . $tblAlias . '.' . $transMeta->getQuotedColumnName('field', $this->platform) . ' = ' . $this->conn->quote($field);
             $identifier = $meta->getSingleIdentifierFieldName();
             $idColName = $meta->getQuotedColumnName($identifier, $this->platform);
             if ($ea->usesPersonalTranslation($transClass)) {
                 $sql .= ' AND ' . $tblAlias . '.' . $transMeta->getSingleAssociationJoinColumnName('object') . ' = ' . $compTblAlias . '.' . $idColName;
             } else {
                 $sql .= ' AND ' . $tblAlias . '.' . $transMeta->getQuotedColumnName('objectClass', $this->platform) . ' = ' . $this->conn->quote($config['useObjectClass']);
                 $mappingFK = $transMeta->getFieldMapping('foreignKey');
                 $mappingPK = $meta->getFieldMapping($identifier);
                 $fkColName = $this->getCastedForeignKey($compTblAlias . '.' . $idColName, $mappingFK['type'], $mappingPK['type']);
                 $sql .= ' AND ' . $tblAlias . '.' . $transMeta->getQuotedColumnName('foreignKey', $this->platform) . ' = ' . $fkColName;
             }
             isset($this->components[$dqlAlias]) ? $this->components[$dqlAlias] .= $sql : ($this->components[$dqlAlias] = $sql);
             $originalField = $compTblAlias . '.' . $meta->getQuotedColumnName($field, $this->platform);
             $substituteField = $tblAlias . '.' . $transMeta->getQuotedColumnName('content', $this->platform);
             // Treat translation as original field type
             $fieldMapping = $meta->getFieldMapping($field);
             if ($this->platform instanceof MySqlPlatform && in_array($fieldMapping["type"], array("decimal")) || !$this->platform instanceof MySqlPlatform && !in_array($fieldMapping["type"], array("datetime", "datetimetz", "date", "time"))) {
                 $type = Type::getType($fieldMapping["type"]);
                 $substituteField = 'CAST(' . $substituteField . ' AS ' . $type->getSQLDeclaration($fieldMapping, $this->platform) . ')';
             }
             // Fallback to original if was asked for
             if ($this->needsFallback() && (!isset($config['fallback'][$field]) || $config['fallback'][$field]) || !$this->needsFallback() && isset($config['fallback'][$field]) && $config['fallback'][$field]) {
                 $substituteField = 'COALESCE(' . $substituteField . ', ' . $originalField . ')';
             }
             $this->replacements[$originalField] = $substituteField;
         }
     }
 }
開發者ID:anhpha,項目名稱:reports,代碼行數:64,代碼來源:TranslationWalker.php

示例13: getSelectObjectIdentityIdSql

    /**
     * Constructs the SQL for retrieving the primary key of the given object
     * identity.
     *
     * @param ObjectIdentityInterface $oid
     *
     * @return string
     */
    protected function getSelectObjectIdentityIdSql(ObjectIdentityInterface $oid)
    {
        $query = <<<QUERY
            SELECT o.id
            FROM %s o
            INNER JOIN %s c ON c.id = o.class_id
            WHERE o.object_identifier = %s AND c.class_type = %s
QUERY;
        return sprintf($query, $this->options['oid_table_name'], $this->options['class_table_name'], $this->connection->quote((string) $oid->getIdentifier()), $this->connection->quote((string) $oid->getType()));
    }
開發者ID:saberyounis,項目名稱:Sonata-Project,代碼行數:18,代碼來源:AclProvider.php

示例14: startQuery

 /**
  * {@inheritdoc}
  */
 public function startQuery($sql, array $params = null, array $types = null)
 {
     if ($params) {
         list($sql, $params, $types) = SQLParserUtils::expandListParameters($sql, $params, $types);
         $query = vsprintf(str_replace('?', "%s", $sql), call_user_func(function () use($params, $types) {
             $quotedParams = array();
             foreach ($params as $typeIndex => $value) {
                 $quotedParams[] = $this->connection->quote($value, $types[$typeIndex]);
             }
             return $quotedParams;
         }));
     } else {
         $query = $sql;
     }
     $this->lastQuery = $query;
     if ($this->outputQuery) {
         $this->output($query);
     }
 }
開發者ID:cmyker,項目名稱:doctrine-sql-logger,代碼行數:22,代碼來源:Logger.php

示例15: quote

 /**
  * {@inheritdoc}
  */
 public function quote($value)
 {
     if (ConnectionDecoratorChain::isDecorate()) {
         return (new ConnectionDecoratorChain($this, $this->decorators))->quote($value);
     }
     try {
         return $this->conn->quote($value);
     } catch (\Exception $e) {
         throw $this->convertException($e);
     }
 }
開發者ID:koolkode,項目名稱:database,代碼行數:14,代碼來源:Connection.php


注:本文中的Doctrine\DBAL\Connection::quote方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。