Also see https://bugs.php.net/bug.php?id=55226

Same idea, but for the PDO_sqlite implementation.

Damien

On Mon, Jan 23, 2012 at 11:28 PM, b dewar <macde...@gmail.com> wrote:
> Hi
>
> I initially sent this to php-db, but I guess it really belongs on internals.
>
> The C API for SQLite3 has an sqlite3_create_collation() feature that's
> missing from PHP's SQLite3 class API.
>
> I'm working on a patch that adds the SQLite3::createCollation(string
> collation_name, mixed callback) method.  This allows registering a PHP
> function as a comparator for the database to use while collating data.
>  The callback passed to createCollation() should act like strcmp(),
> i.e. it should accept two strings and return an integer indicating
> their relative sort order.
>
> e.g.
>
> <?php
>
> $filenames = array(
>   'ab1.png',
>   'ab2.png',
>   'ab10.png',
>   'ab11.png',
>   'ac.png',
>   'aa.png',
>   'ab3.png');
>
> $db = new SQLite3(':memory:');
>
> $db->createCollation('NATURAL_SORT', 'strnatcmp');
>
> $db->exec("CREATE TABLE filenames (fname varchar(32));");
>
> $stmt = $db->prepare("INSERT INTO filenames VALUES (?);");
> foreach($filenames as $fname){
>   $stmt->bindParam(1, $fname);
>   $stmt->execute();
> }
> $result = $db->query("SELECT fname FROM filenames ORDER BY fname
> COLLATE NATURAL_SORT;");
> while($row = $result->fetchArray()){
>   echo $row['fname'], "\n";
> }
>
> $db->close();
>
> ?>
>
> Output:
>
> aa.png
> ab1.png
> ab2.png
> ab3.png
> ab10.png
> ab11.png
> ac.png
>
>
>
> I've built 5.3.9 with my patch on Ubuntu on x86_64, and it works as
> expected. I've never submitted a patch for PHP before, so I could use
> some advice/hand-holding on the process.
>
> Thanks,
> Brad
>
> --
> PHP Internals - PHP Runtime Development Mailing List
> To unsubscribe, visit: http://www.php.net/unsub.php
>

--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to