Page MenuHomePhabricator

Support "%R" (Database + Table Ref) in qsprintf(...)
ClosedPublic

Authored by epriestley on Oct 26 2018, 3:09 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Dec 21, 2:18 AM
Unknown Object (File)
Sat, Dec 14, 9:53 AM
Unknown Object (File)
Dec 8 2024, 3:51 AM
Unknown Object (File)
Dec 1 2024, 11:38 AM
Unknown Object (File)
Dec 1 2024, 11:38 AM
Unknown Object (File)
Dec 1 2024, 11:38 AM
Unknown Object (File)
Dec 1 2024, 11:38 AM
Unknown Object (File)
Nov 22 2024, 11:05 AM
Subscribers
None

Details

Summary

Ref T13210. Ref T11908. In the future, we'd like to be able to use one port-to-port database connection to issue queries for multiple databases (e.g., both Differential and Maniphest) if both applications are on the same host.

The big issue with this is that we currently run queries like SELECT * FROM xyz, and assume the database name based on the connection state. Instead, we want to run SELECT * FROM abc.xyz, which will work no matter which database the connection is currently USE ..-ing.

To support this, add a %R conversion to qsprintf(...) which takes a "database + table ref" object. This is a new type of object which stores both a database name and a table name, so we can build "abc.xyz".

Test Plan

See the next change for callsites and unit tests.

Diff Detail

Repository
rPHU libphutil
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

amckinley added inline comments.
src/xsprintf/qsprintf.php
242

I'm assuming it's fine to use escapeColumnName() on DB and table names?

This revision is now accepted and ready to land.Oct 31 2018, 7:10 PM

Yeah -- the actual escaping rules are the same for databases, tables, and columns. Possibly the interface should separate them or call the method escapeTableOrDatabaseOrColumnName() but it seems unlikely that we'll support an alternate SQL implementation any time too soon.

This revision was automatically updated to reflect the committed changes.