Nesta página, descrevemos os drivers compatíveis com o Spanner para bancos de dados do dialeto GoogleSQL e do dialeto PostgreSQL.
O Google oferece suporte a drivers do Spanner de código aberto para várias bibliotecas e frameworks conhecidos de mapeamento relacional de objetos (ORM). Esses drivers permitem o uso de bancos de dados do Spanner por meio de APIs definidas por esses frameworks.
As tabelas a seguir listam todos os ORMs e drivers de código aberto compatíveis com o Spanner e os recursos que cada um oferece. Há uma tabela para cada dialeto SQL compatível.
Também é possível usar as bibliotecas de cliente do Spanner para acessar a API Spanner. Para mais informações, consulte Bibliotecas de cliente do Spanner.
Drivers e ORMs do GoogleSQL
| Recurso | database/sql | GORM | JDBC do Spanner | Hibernate | Dados do Spring | R2DBC* | Entity Framework | Active Record | SQLAlchemy | Django | NHibernate |
|---|---|---|---|---|---|---|---|---|---|---|---|
| Idioma | Go | Go | Java | Java | Java | Java | C# | Ruby | Python | Python | C# |
| Dicas de instrução | † | ||||||||||
| Mutações | |||||||||||
| DML em lote | |||||||||||
| DDL em lote | |||||||||||
| Leituras desatualizadas | |||||||||||
| Tabelas intercaladas | |||||||||||
| DML particionada | |||||||||||
| Rotulagem de sessão | |||||||||||
| Prioridade da solicitação | |||||||||||
| Tipo JSON | |||||||||||
| Inclusão de tags de solicitação | |||||||||||
| Dialeto SQL do Google | |||||||||||
| Dialeto do PostgreSQL | |||||||||||
| Limitações | Ver | Ver | Ver | Ver | Ver | Ver | Ver |
* Esta coluna descreve o R2DBC quando usado especificamente com dados do Spring.
† Disponível apenas ao enviar consultas SQL literais usando a anotação @Query
de dados do Spring.
Drivers e ORMs do PostgreSQL
Todos os drivers do PostgreSQL exigem que o proxy PGAdapter esteja em execução. Veja mais informações em Sobre o PGAdapter.
| Recurso | JDBC do Spanner | JDBC do PostgreSQL | Hibernate | pgx | GORM | psycopg2 | psycopg3 | SQLAlchemy 2 | node-postgres |
|---|---|---|---|---|---|---|---|---|---|
| Idioma | Java | Java | Java | Go | Go | Python | Python | Python | Node.js |
| Dicas de instrução | |||||||||
| Mutações | |||||||||
| DML em lote | |||||||||
| DDL em lote | |||||||||
| Leituras desatualizadas | |||||||||
| Tabelas intercaladas | |||||||||
| DML particionada | |||||||||
| Rotulagem de sessão | |||||||||
| Prioridade da solicitação | |||||||||
| Inclusão de tags de solicitação | |||||||||
| Limitações | Ver | Ver | Ver | Ver | Ver | Ver | Ver | Ver |