{"bundle_type":"pith_open_graph_bundle","bundle_version":"1.0","pith_number":"pith:2010:4B6OBJ2D6MJPUQBOYIJG3ABC3D","short_pith_number":"pith:4B6OBJ2D","canonical_record":{"source":{"id":"1009.1166","kind":"arxiv","version":4},"metadata":{"license":"http://creativecommons.org/licenses/by/3.0/","primary_cat":"cs.DB","submitted_at":"2010-09-06T21:05:23Z","cross_cats_sorted":["math.CT"],"title_canon_sha256":"d4633dace5c8a223d8b3e809b29fee206b2b375f67c22c892ae927bc910d4625","abstract_canon_sha256":"d7643ad39c215ca54eabb2c23aa343b58308103bd05fe0c514fd502c6bc649b1"},"schema_version":"1.0"},"canonical_sha256":"e07ce0a743f312fa402ec2126d8022d8ed88f79f2a49f9c4ee8c80c4451d64cb","source":{"kind":"arxiv","id":"1009.1166","version":4},"source_aliases":[{"alias_kind":"arxiv","alias_value":"1009.1166","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"arxiv_version","alias_value":"1009.1166v4","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.1009.1166","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"pith_short_12","alias_value":"4B6OBJ2D6MJP","created_at":"2026-05-18T12:26:03Z"},{"alias_kind":"pith_short_16","alias_value":"4B6OBJ2D6MJPUQBO","created_at":"2026-05-18T12:26:03Z"},{"alias_kind":"pith_short_8","alias_value":"4B6OBJ2D","created_at":"2026-05-18T12:26:03Z"}],"events":[{"event_type":"record_created","subject_pith_number":"pith:2010:4B6OBJ2D6MJPUQBOYIJG3ABC3D","target":"record","payload":{"canonical_record":{"source":{"id":"1009.1166","kind":"arxiv","version":4},"metadata":{"license":"http://creativecommons.org/licenses/by/3.0/","primary_cat":"cs.DB","submitted_at":"2010-09-06T21:05:23Z","cross_cats_sorted":["math.CT"],"title_canon_sha256":"d4633dace5c8a223d8b3e809b29fee206b2b375f67c22c892ae927bc910d4625","abstract_canon_sha256":"d7643ad39c215ca54eabb2c23aa343b58308103bd05fe0c514fd502c6bc649b1"},"schema_version":"1.0"},"canonical_sha256":"e07ce0a743f312fa402ec2126d8022d8ed88f79f2a49f9c4ee8c80c4451d64cb","receipt":{"kind":"pith_receipt","key_id":"pith-v1-2026-05","algorithm":"ed25519","signed_at":"2026-05-18T03:34:46.568927Z","signature_b64":"xMA4QjKwGc0G4AOo84mZKYF2a6PMJvH6SMoB+FQtki7lqjT6u2ZkvoXp7NlX1zH02SvRFwO9X3bqWkkLioP0BA==","signed_message":"canonical_sha256_bytes","builder_version":"pith-number-builder-2026-05-17-v1","receipt_version":"0.3","canonical_sha256":"e07ce0a743f312fa402ec2126d8022d8ed88f79f2a49f9c4ee8c80c4451d64cb","last_reissued_at":"2026-05-18T03:34:46.568420Z","signature_status":"signed_v1","first_computed_at":"2026-05-18T03:34:46.568420Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"source_kind":"arxiv","source_id":"1009.1166","source_version":4,"attestation_state":"computed"},"signer":{"signer_id":"pith.science","signer_type":"pith_registry","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"created_at":"2026-05-18T03:34:46Z","supersedes":[],"prev_event":null,"signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"7y2YdM0ViKuy8M7xyYBfnPhjf5TAAzR7IIDYRhaeob964yJ0weufxRkKibGJTXMebgwHdC52OrMnfkKhIk5WCA==","signed_message":"open_graph_event_sha256_bytes","signed_at":"2026-05-25T03:14:22.501947Z"},"content_sha256":"23612d16fdbbd279ccaad486fd1bdc34eed1e35c339613d61c33b7d41f559f46","schema_version":"1.0","event_id":"sha256:23612d16fdbbd279ccaad486fd1bdc34eed1e35c339613d61c33b7d41f559f46"},{"event_type":"graph_snapshot","subject_pith_number":"pith:2010:4B6OBJ2D6MJPUQBOYIJG3ABC3D","target":"graph","payload":{"graph_snapshot":{"paper":{"title":"Functorial Data Migration","license":"http://creativecommons.org/licenses/by/3.0/","headline":"","cross_cats":["math.CT"],"primary_cat":"cs.DB","authors_text":"David I. Spivak","submitted_at":"2010-09-06T21:05:23Z","abstract_excerpt":"In this paper we present a simple database definition language: that of categories and functors. A database schema is a small category and an instance is a set-valued functor on it. We show that morphisms of schemas induce three \"data migration functors\", which translate instances from one schema to the other in canonical ways. These functors parameterize projections, unions, and joins over all tables simultaneously and can be used in place of conjunctive and disjunctive queries. We also show how to connect a database and a functional programming language by introducing a functorial connection"},"claims":{"count":0,"items":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"source":{"id":"1009.1166","kind":"arxiv","version":4},"verdict":{"id":null,"model_set":{},"created_at":null,"strongest_claim":"","one_line_summary":"","pipeline_version":null,"weakest_assumption":"","pith_extraction_headline":""},"references":{"count":0,"sample":[],"resolved_work":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57","internal_anchors":0},"formal_canon":{"evidence_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"author_claims":{"count":0,"strong_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"builder_version":"pith-number-builder-2026-05-17-v1"},"verdict_id":null},"signer":{"signer_id":"pith.science","signer_type":"pith_registry","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"created_at":"2026-05-18T03:34:46Z","supersedes":[],"prev_event":null,"signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"yyyqLlZ88pD2eSzNh4ZGJEw91KAn8Kg44kZAoFMnA0SmOQlqthmh7CJC5FcJtv/iHrig4QOd75MVgdm/6T4fDA==","signed_message":"open_graph_event_sha256_bytes","signed_at":"2026-05-25T03:14:22.502422Z"},"content_sha256":"d7e0e57694516ae8c35d5bc9a5985db56eae1209d5dc7d8cbb7d0d048ad227a8","schema_version":"1.0","event_id":"sha256:d7e0e57694516ae8c35d5bc9a5985db56eae1209d5dc7d8cbb7d0d048ad227a8"}],"timestamp_proofs":[],"mirror_hints":[{"mirror_type":"https","name":"Pith Resolver","base_url":"https://pith.science","bundle_url":"https://pith.science/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/bundle.json","state_url":"https://pith.science/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/state.json","well_known_bundle_url":"https://pith.science/.well-known/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/bundle.json","status":"primary"}],"public_keys":[{"key_id":"pith-v1-2026-05","algorithm":"ed25519","format":"raw","public_key_b64":"stVStoiQhXFxp4s2pdzPNoqVNBMojDU/fJ2db5S3CbM=","public_key_hex":"b2d552b68890857171a78b36a5dccf368a953413288c353f7c9d9d6f94b709b3","fingerprint_sha256_b32_first128bits":"RVFV5Z2OI2J3ZUO7ERDEBCYNKS","fingerprint_sha256_hex":"8d4b5ee74e4693bcd1df2446408b0d54","rotates_at":null,"url":"https://pith.science/pith-signing-key.json","notes":"Pith uses this Ed25519 key to sign canonical record SHA-256 digests. Verify with: ed25519_verify(public_key, message=canonical_sha256_bytes, signature=base64decode(signature_b64))."}],"merge_version":"pith-open-graph-merge-v1","built_at":"2026-05-25T03:14:22Z","links":{"resolver":"https://pith.science/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D","bundle":"https://pith.science/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/bundle.json","state":"https://pith.science/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/state.json","well_known_bundle":"https://pith.science/.well-known/pith/4B6OBJ2D6MJPUQBOYIJG3ABC3D/bundle.json"},"state":{"state_type":"pith_open_graph_state","state_version":"1.0","pith_number":"pith:2010:4B6OBJ2D6MJPUQBOYIJG3ABC3D","merge_version":"pith-open-graph-merge-v1","event_count":2,"valid_event_count":2,"invalid_event_count":0,"equivocation_count":0,"current":{"canonical_record":{"metadata":{"abstract_canon_sha256":"d7643ad39c215ca54eabb2c23aa343b58308103bd05fe0c514fd502c6bc649b1","cross_cats_sorted":["math.CT"],"license":"http://creativecommons.org/licenses/by/3.0/","primary_cat":"cs.DB","submitted_at":"2010-09-06T21:05:23Z","title_canon_sha256":"d4633dace5c8a223d8b3e809b29fee206b2b375f67c22c892ae927bc910d4625"},"schema_version":"1.0","source":{"id":"1009.1166","kind":"arxiv","version":4}},"source_aliases":[{"alias_kind":"arxiv","alias_value":"1009.1166","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"arxiv_version","alias_value":"1009.1166v4","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.1009.1166","created_at":"2026-05-18T03:34:46Z"},{"alias_kind":"pith_short_12","alias_value":"4B6OBJ2D6MJP","created_at":"2026-05-18T12:26:03Z"},{"alias_kind":"pith_short_16","alias_value":"4B6OBJ2D6MJPUQBO","created_at":"2026-05-18T12:26:03Z"},{"alias_kind":"pith_short_8","alias_value":"4B6OBJ2D","created_at":"2026-05-18T12:26:03Z"}],"graph_snapshots":[{"event_id":"sha256:d7e0e57694516ae8c35d5bc9a5985db56eae1209d5dc7d8cbb7d0d048ad227a8","target":"graph","created_at":"2026-05-18T03:34:46Z","signer":{"key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signer_id":"pith.science","signer_type":"pith_registry"},"payload":{"graph_snapshot":{"author_claims":{"count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57","strong_count":0},"builder_version":"pith-number-builder-2026-05-17-v1","claims":{"count":0,"items":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"formal_canon":{"evidence_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"paper":{"abstract_excerpt":"In this paper we present a simple database definition language: that of categories and functors. A database schema is a small category and an instance is a set-valued functor on it. We show that morphisms of schemas induce three \"data migration functors\", which translate instances from one schema to the other in canonical ways. These functors parameterize projections, unions, and joins over all tables simultaneously and can be used in place of conjunctive and disjunctive queries. We also show how to connect a database and a functional programming language by introducing a functorial connection","authors_text":"David I. Spivak","cross_cats":["math.CT"],"headline":"","license":"http://creativecommons.org/licenses/by/3.0/","primary_cat":"cs.DB","submitted_at":"2010-09-06T21:05:23Z","title":"Functorial Data Migration"},"references":{"count":0,"internal_anchors":0,"resolved_work":0,"sample":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"source":{"id":"1009.1166","kind":"arxiv","version":4},"verdict":{"created_at":null,"id":null,"model_set":{},"one_line_summary":"","pipeline_version":null,"pith_extraction_headline":"","strongest_claim":"","weakest_assumption":""}},"verdict_id":null}}],"author_attestations":[],"timestamp_anchors":[],"storage_attestations":[],"citation_signatures":[],"replication_records":[],"corrections":[],"mirror_hints":[],"record_created":{"event_id":"sha256:23612d16fdbbd279ccaad486fd1bdc34eed1e35c339613d61c33b7d41f559f46","target":"record","created_at":"2026-05-18T03:34:46Z","signer":{"key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signer_id":"pith.science","signer_type":"pith_registry"},"payload":{"attestation_state":"computed","canonical_record":{"metadata":{"abstract_canon_sha256":"d7643ad39c215ca54eabb2c23aa343b58308103bd05fe0c514fd502c6bc649b1","cross_cats_sorted":["math.CT"],"license":"http://creativecommons.org/licenses/by/3.0/","primary_cat":"cs.DB","submitted_at":"2010-09-06T21:05:23Z","title_canon_sha256":"d4633dace5c8a223d8b3e809b29fee206b2b375f67c22c892ae927bc910d4625"},"schema_version":"1.0","source":{"id":"1009.1166","kind":"arxiv","version":4}},"canonical_sha256":"e07ce0a743f312fa402ec2126d8022d8ed88f79f2a49f9c4ee8c80c4451d64cb","receipt":{"algorithm":"ed25519","builder_version":"pith-number-builder-2026-05-17-v1","canonical_sha256":"e07ce0a743f312fa402ec2126d8022d8ed88f79f2a49f9c4ee8c80c4451d64cb","first_computed_at":"2026-05-18T03:34:46.568420Z","key_id":"pith-v1-2026-05","kind":"pith_receipt","last_reissued_at":"2026-05-18T03:34:46.568420Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","receipt_version":"0.3","signature_b64":"xMA4QjKwGc0G4AOo84mZKYF2a6PMJvH6SMoB+FQtki7lqjT6u2ZkvoXp7NlX1zH02SvRFwO9X3bqWkkLioP0BA==","signature_status":"signed_v1","signed_at":"2026-05-18T03:34:46.568927Z","signed_message":"canonical_sha256_bytes"},"source_id":"1009.1166","source_kind":"arxiv","source_version":4}}},"equivocations":[],"invalid_events":[],"applied_event_ids":["sha256:23612d16fdbbd279ccaad486fd1bdc34eed1e35c339613d61c33b7d41f559f46","sha256:d7e0e57694516ae8c35d5bc9a5985db56eae1209d5dc7d8cbb7d0d048ad227a8"],"state_sha256":"7137b12a3e678bfa3dea6f80e513cc101e7169997a7e1492fc29a1335ba9705c"},"bundle_signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"ZzNmL9hViolSDpAnCAm//ty8b4+ue57g9p64lWoykPTTfbxE+S+GLqVDfgDqytxUDx9FMSS/KBCpdMofW/y5Aw==","signed_message":"bundle_sha256_bytes","signed_at":"2026-05-25T03:14:22.505499Z","bundle_sha256":"09d9e6f0921e22bad9d3e7a75ea1db4762789d428c383497b450880026e5bbc9"}}