


Mastering Complex Sort Logic with `usort` and Custom Callbacks
Aug 03, 2025 am 09:07 AMUse usort() to solve the multi-condition sorting problem of complex data in PHP. 1. Define the sorting logic through a custom callback function and use the operator to return -1, 0 or 1; 2. When implementing multi-level sorting, first compare the main fields, and if equal, enter the secondary fields step by step; 3. Create dynamic callback functions to flexibly adjust the sorting fields and directions according to the configuration array; 4. Support complex types such as date and calculated values, but preprocessing and time-consuming operations are required to improve performance; 5. If the original key name is required, uasort() should be used instead of usort(); finally, efficient and maintainable intelligent sorting is achieved through structured callbacks, and the complete ends.
Sorting arrays in PHP is straightforward when dealing with simple data types—just use sort()
, asort()
, or ksort()
and you're done. But what happens when you need to sort complex data, like an array of associated arrays or objects, based on multiple conditions, dynamic rules, or non-standard comparisons? That's where usort()
and custom callbacks shine.

Unlike basic sorting functions, usort()
lets you define your own comparison logic through a callback function. This opens the door to powerful, flexible sorting behavior that can handle almost any scenario.
How usort()
Works
usort()
takes two arguments: the array to sort and a callback function that defines the sort order. The callback receives two elements from the array and must return an integer:

- Negative value if the first element should come before the second
- Zero if they are equal
- Positive value if the first should come after the second
usort($array, function($a, $b) { return $a['value'] <=> $b['value']; });
The <=>
(spaceship operator) simplifies comparisons by returning -1, 0, or 1 depending on whether the left operand is less than, equal to, or greater than the right.
Sorting by Multiple Criteria
One common challenge is sorting by more than one field. For example, imagine you have an array of users and want to sort by last name, then by first name.

$users = [ ['first' => 'John', 'last' => 'Doe'], ['first' => 'Jane', 'last' => 'Doe'], ['first' => 'Alice', 'last' => 'Smith'], ]; usort($users, function($a, $b) { // First, compare last names $result = $a['last'] <=> $b['last']; // If last names are the same, compare first names return $result !== 0 ? $result : ($a['first'] <=> $b['first']); });
This pattern can be extended to three or more fields. Just keep nesting fallback comparisons.
You can also make it more readable by using a helper approach:
usort($users, function($a, $b) { if (($cmp = $a['last'] <=> $b['last']) !== 0) return $cmp; if (($cmp = $a['first'] <=> $b['first']) !== 0) return $cmp; return 0; });
Dynamic and Configurable Sorting
Sometimes, you don't know the sort criteria at runtime. You might want to sort by different fields based on user input or configuration.
You can create a reusable callback generator:
function createSortCallback($sortKeys) { return function($a, $b) use ($sortKeys) { foreach ($sortKeys as $key => $direction) { $direction = strtolower($direction) === 'desc' ? -1 : 1; $valA = $a[$key] ?? null; $valB = $b[$key] ?? null; if ($valA !== $valB) { $cmp = $valA <=> $valB; return $direction * $cmp; } } return 0; }; } // Usage: sort by last name ascending, then first name descending $callback = createSortCallback(['last' => 'asc', 'first' => 'desc']); usort($users, $callback);
This makes your sorting logic reusable and driven by configuration.
Handling Complex Data Types
usort()
isn't limited to strings and numbers. You can sort by dates, calculated values, or even nested structures.
For example, sorting events by date (assuming dates are strings or timestamps):
$events = [ ['name' => 'Event A', 'date' => '2023-12-01'], ['name' => 'Event B', 'date' => '2023-11-15'], ]; usort($events, function($a, $b) { $dateA = strtotime($a['date']); $dateB = strtotime($b['date']); return $dateA <=> $dateB; });
Or sorting products by discounted price:
$products = [ ['name' => 'Laptop', 'price' => 1000, 'discount' => 0.1], ['name' => 'Phone', 'price' => 800, 'discount' => 0.2], ]; usort($products, function($a, $b) { $finalA = $a['price'] * (1 - $a['discount']); $finalB = $b['price'] * (1 - $b['discount']); return $finalA <=> $finalB; });
Performance Considerations
While usort()
is powerful, each comparison calls your callback, so avoid expensive operations inside it. For example, don't repeatedly parse dates or make database calls in the callback.
Instead, precompute values when possible:
// Precompute timestamps foreach ($events as &$event) { $event['timestamp'] = strtotime($event['date']); } unset($event); usort($events, function($a, $b) { return $a['timestamp'] <=> $b['timestamp']; });
Also, remember that usort()
reindexes the array and doesn't preserve keys—use uasort()
if you need to keep original keys.
Summary
- Use
usort()
when sorting complex data that requires custom logic - Chain comparisons with the spaceship operator for multi-level sorting
- Build dynamic sort callbacks using closures and configuration
- Precompute expensive values to avoid performance hits
- Choose
uasort()
overusort()
if key preservation matters
With well-structured callbacks, usort()
becomes a versatile tool for handling real-world sorting challenges in PHP. It's not just about ordering data—it's about doing so intelligently and maintainably.
Basically, once you get the hang of writing comparison logic, the rest is just pattern and performance.
The above is the detailed content of Mastering Complex Sort Logic with `usort` and Custom Callbacks. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Common problems and solutions for PHP variable scope include: 1. The global variable cannot be accessed within the function, and it needs to be passed in using the global keyword or parameter; 2. The static variable is declared with static, and it is only initialized once and the value is maintained between multiple calls; 3. Hyperglobal variables such as $_GET and $_POST can be used directly in any scope, but you need to pay attention to safe filtering; 4. Anonymous functions need to introduce parent scope variables through the use keyword, and when modifying external variables, you need to pass a reference. Mastering these rules can help avoid errors and improve code stability.

To safely handle PHP file uploads, you need to verify the source and type, control the file name and path, set server restrictions, and process media files twice. 1. Verify the upload source to prevent CSRF through token and detect the real MIME type through finfo_file using whitelist control; 2. Rename the file to a random string and determine the extension to store it in a non-Web directory according to the detection type; 3. PHP configuration limits the upload size and temporary directory Nginx/Apache prohibits access to the upload directory; 4. The GD library resaves the pictures to clear potential malicious data.

There are three common methods for PHP comment code: 1. Use // or # to block one line of code, and it is recommended to use //; 2. Use /.../ to wrap code blocks with multiple lines, which cannot be nested but can be crossed; 3. Combination skills comments such as using /if(){}/ to control logic blocks, or to improve efficiency with editor shortcut keys, you should pay attention to closing symbols and avoid nesting when using them.

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

The key to writing PHP comments is to clarify the purpose and specifications. Comments should explain "why" rather than "what was done", avoiding redundancy or too simplicity. 1. Use a unified format, such as docblock (/*/) for class and method descriptions to improve readability and tool compatibility; 2. Emphasize the reasons behind the logic, such as why JS jumps need to be output manually; 3. Add an overview description before complex code, describe the process in steps, and help understand the overall idea; 4. Use TODO and FIXME rationally to mark to-do items and problems to facilitate subsequent tracking and collaboration. Good annotations can reduce communication costs and improve code maintenance efficiency.

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

In PHP, you can use square brackets or curly braces to obtain string specific index characters, but square brackets are recommended; the index starts from 0, and the access outside the range returns a null value and cannot be assigned a value; mb_substr is required to handle multi-byte characters. For example: $str="hello";echo$str[0]; output h; and Chinese characters such as mb_substr($str,1,1) need to obtain the correct result; in actual applications, the length of the string should be checked before looping, dynamic strings need to be verified for validity, and multilingual projects recommend using multi-byte security functions uniformly.

TolearnPHPeffectively,startbysettingupalocalserverenvironmentusingtoolslikeXAMPPandacodeeditorlikeVSCode.1)InstallXAMPPforApache,MySQL,andPHP.2)Useacodeeditorforsyntaxsupport.3)TestyoursetupwithasimplePHPfile.Next,learnPHPbasicsincludingvariables,ech
