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


PHP DatabaseConnection::escape方法代碼示例

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


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

示例1: commit

    public function commit(array $attributes)
    {
        //TODO: move all this logic to the query class

        // Get the node type
        $type = $this->getType();

        // Determine the correct context
        if (is_string($attributes['context']))
        {
            // Use the passed context
            $attributes['context'] = MeshTools::GetContextPks($attributes['context']);
        }
        else if (!$attributes['context'])
        {
            if ($this->pk)
            {
                // Bypass context on existing nodes if not explicitly passed in
                unset($attributes['context']);
            }
            else
            {
                // For new nodes use the default context
                $attributes['context'] = (array)MeshTools::GetDefaultContextPk();

                if (empty($attributes['context']))      // for non-context setups
                {
                    unset($attributes['context']);
                }

            }
        }

        if (! isset($attributes['context']))
        {
            // Do nothing, bypass context updates
        }
        else if (1 == count($attributes['context']))
        {
            $attributes['context'] = $attributes['context'][0];
        }
        else        // @todo New nodes can only have one context
        {
            throw new Exception('Cannot create node with ambiguous context');
        }


        // Separate the attirbutes from the links
        foreach ($attributes as $key => $value)
        {
            // Link Nodes if not attributes
            if (! $this->_isAttribute($key))
            {
                // Use only valid node types
                if ($this->_isNodeType($key))
                {
                    // Copy the attribute to the links array
                    $links[$key] = $attributes[$key];
                }
                else
                {
                    throw new Exception('Cannot link '.$type.' with '.$key.' because type '.$key.' doesn\'t exist.');
                }

                // Remove all non-attirbutes from the attributes array
                unset($attributes[$key]);
            }
        }

        try
        {
            // First update/insert the attributes
            // If the node exists then peform update, otherwise insert
            if ($this->pk)
            {
                // cache the data for this node
                $this->_cache->populate($attributes);

                $dbc = new DatabaseConnection();

                $sql = "UPDATE $type SET ";

                foreach ($attributes as $key => $value)
                {
                    $sql .= " $key = '".$dbc->escape($value)."', ";
                }

                $sql    = rtrim($sql, ', ');
                $sql    .= " WHERE pk = $this->pk";

                $dbc->query($sql);
            }
            else
            {
                // cache the data for this node
                $this->_cache->populate($attributes);

                $dbc = new DatabaseConnection();

                // Clean the attributes
//.........這裏部分代碼省略.........
開發者ID:Goodgulf,項目名稱:nodemesh,代碼行數:101,代碼來源:class.Node.php

示例2: execute

 function execute()
 {
     $db = new DatabaseConnection();
     $stmt = "INSERT INTO " . $this->table . " ";
     $rd = array();
     foreach ($this->insert[0] as $key => $val) {
         $rd[] = $key;
     }
     $stmt .= "(" . join(',', $rd) . ") VALUES ";
     $si = array();
     foreach ($this->insert as $row) {
         $sr = array();
         foreach ($row as $key => $val) {
             $sr[] = $db->escape('%s', $val);
         }
         $si[] = '(' . join(',', $sr) . ')';
     }
     $stmt .= join(', ', $si);
     return $db->insertRow($stmt);
 }
開發者ID:noccy80,項目名稱:lepton-ng,代碼行數:20,代碼來源:simpleql.php


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