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 |