]> source.dussan.org Git - nextcloud-server.git/commitdiff
fixes #329: query the database in chunks of 200
authorThomas Mueller <thomas.mueller@tmit.eu>
Mon, 5 Nov 2012 21:42:03 +0000 (22:42 +0100)
committerThomas Mueller <thomas.mueller@tmit.eu>
Mon, 5 Nov 2012 21:42:03 +0000 (22:42 +0100)
lib/connector/sabre/directory.php

index b6e02569d2a34168bf4491716c45ebc0d2b6ee14..388936bc96e0a9cac83a0344537010f1edb6ea31 100644 (file)
@@ -116,7 +116,6 @@ class OC_Connector_Sabre_Directory extends OC_Connector_Sabre_Node implements Sa
         * @return Sabre_DAV_INode[]
         */
        public function getChildren() {
-
                $folder_content = OC_Files::getDirectoryContent($this->path);
                $paths = array();
                foreach($folder_content as $info) {
@@ -124,15 +123,18 @@ class OC_Connector_Sabre_Directory extends OC_Connector_Sabre_Node implements Sa
                }
                $properties = array_fill_keys($paths, array());
                if(count($paths)>0) {
-                       $placeholders = join(',', array_fill(0, count($paths), '?'));
-                       $query = OC_DB::prepare( 'SELECT * FROM `*PREFIX*properties` WHERE `userid` = ?' . ' AND `propertypath` IN ('.$placeholders.')' );
-                       array_unshift($paths, OC_User::getUser()); // prepend userid
-                       $result = $query->execute( $paths );
-                       while($row = $result->fetchRow()) {
-                               $propertypath = $row['propertypath'];
-                               $propertyname = $row['propertyname'];
-                               $propertyvalue = $row['propertyvalue'];
-                               $properties[$propertypath][$propertyname] = $propertyvalue;
+                       $chunks = array_chunk($paths, 200, false);
+                       foreach ($chunks as $pack) {
+                               $placeholders = join(',', array_fill(0, count($pack), '?'));
+                               $query = OC_DB::prepare( 'SELECT * FROM `*PREFIX*properties` WHERE `userid` = ?' . ' AND `propertypath` IN ('.$placeholders.')' );
+                               array_unshift($pack, OC_User::getUser()); // prepend userid
+                               $result = $query->execute( $pack );
+                               while($row = $result->fetchRow()) {
+                                       $propertypath = $row['propertypath'];
+                                       $propertyname = $row['propertyname'];
+                                       $propertyvalue = $row['propertyvalue'];
+                                       $properties[$propertypath][$propertyname] = $propertyvalue;
+                               }
                        }
                }