Page MenuHomeDevCentral

Fetch a scalar value from a result
ClosedPublic

Authored by dereckson on Nov 1 2025, 12:05.
Tags
None
Referenced Files
F25030402: D3838.diff
Thu, Mar 26, 07:00
F25030350: D3838.id9935.diff
Thu, Mar 26, 06:58
F25023692: D3838.diff
Wed, Mar 25, 21:29
Unknown Object (File)
Wed, Mar 25, 05:08
Unknown Object (File)
Tue, Mar 24, 20:06
Unknown Object (File)
Tue, Mar 24, 10:45
Unknown Object (File)
Tue, Mar 24, 10:07
Unknown Object (File)
Fri, Mar 20, 12:10
Subscribers
None

Details

Summary

While queryScalar is useful for fetching scalar values in queries like
SELECT count(*), it cannot be used with prepared statements in PDO.

DatabaseResult::fetchScalar returns the first item of the next row.

The following fluent pattern is now supported:

$sql = "SELECT count(*) FROM foo WHERE id = :id";

return $this->db
    ->prepare($sql)
    ->with("id", $this->id)
    ->query()
    ->fetchScalar();

fetchScalar is implemented at DatabaseResult level, making it available
with all drivers, not just PDO.

Ref T2169

Test Plan
  • New unit test for current Result tests classes
  • Tested with D3835 on Obsidian codebase

Diff Detail

Repository
rKERUALD Keruald libraries development repository
Lint
Lint Passed
Unit
Tests Passed
Branch
main
Build Status
Buildable 6130
Build 6414: arc lint + arc unit

Event Timeline

dereckson created this revision.
dereckson edited the test plan for this revision. (Show Details)
dereckson added a child revision: D3835: Read from Orbeon Forms.
This revision is now accepted and ready to land.Nov 1 2025, 12:09