I went to a talk on a paper called "Querying and Maintaining a Compact XML Storage" by Raymond Wong, Franky Lam, and William Shui. Here's the abstract and here's the paper (PDF). The authors created a clever encoding of XML that not only takes much less storage, but is also much faster. For example, here's some data he shows for a 100Mb XML document (compared to MS Vista's native XML libraries):
data:image/s3,"s3://crabby-images/79c5d/79c5d3a3d8022484607a4436a4027be763f19b22" alt="Performance results of ISX on 100Mb XML
document Performance results of ISX on 100Mb XML document"
The results are sufficient that you could imagine doing this on a mobile phone, for example.