La asistencia de Looker para Oracle se implementó mediante implementaciones tradicionales de Oracle. Si tu base de datos de Oracle es una implementación de RAC de Oracle, Looker puede integrarse con éxito, pero puede tener problemas para finalizar las consultas debido a una diferencia en los metadatos para recuperar los ID de conexión de consulta de los nodos.
Encripta el tráfico de red
Looker recomienda que encripte el tráfico de red entre la aplicación de Looker y su base de datos. Considera una de las opciones descritas en la página de documentación Habilita el acceso seguro a la base de datos.
Si te interesa usar la encriptación SSL, consulta la documentación de Oracle.
Crea un usuario de Looker
Primero, crea un usuario designado de Looker:
-- connect / as sysdba;
CREATE USER LOOKER IDENTIFIED BY <password>
DEFAULT TABLESPACE USERS
TEMPORARY TABLESPACE TEMP;
A continuación, otórguele al usuario de Looker la capacidad de crear sesiones:
GRANT CREATE SESSION TO LOOKER;
Por último, otórgale al usuario de Looker los permisos SELECT
apropiados para las tablas de datos a las que planeas acceder desde Looker. Si desea acceder a tablas adicionales en el futuro, también deberá otorgar el permiso SELECT
en esas tablas.
GRANT SELECT ON -- <all tables that will be used by looker>;
Cómo asegurarse de que Looker pueda ver todas las tablas
Es posible que Looker no pueda identificar tablas (especialmente tablas vacías) sin primero recopilar estadísticas en Oracle. Si las tablas que necesitas no aparecen en LookML o Runner de SQL generado, intenta ejecutar lo siguiente:
EXEC DBMS_STATS.GATHER_DATABASE_STATS;
Para conocer otros métodos, consulta la documentación de Oracle.
Configurar objetos de la base de datos principal
Tu DBA de Oracle debe configurar los siguientes objetos y permisos en Oracle. Los siguientes comandos crean LOOKER_SESSION
y LOOKER_SQL
como sinónimos de V$SESSION
y V$SQL
.
Ejecuta los siguientes comandos como usuario raíz para completar esta configuración. En estos ejemplos, se supone que el nombre del usuario de Looker es LOOKER
.
CREATE OR REPLACE VIEW LOOKER_SQL
AS
SELECT
sql.SQL_ID,
sql.SQL_TEXT
FROM
V$SQL sql,
v$session sess
WHERE
sess.SQL_ADDRESS = sql.ADDRESS AND
sess.username='LOOKER';
CREATE OR REPLACE SYNONYM LOOKER.LOOKER_SQL FOR LOOKER_SQL;
GRANT SELECT ON LOOKER.LOOKER_SQL TO LOOKER;
-- Pay special attention to the comments below:
-- the following view will be different for clustered Oracle deployments
CREATE OR REPLACE VIEW LOOKER_SESSION
AS
SELECT
SID,
USERNAME,
TYPE,
STATUS,
SQL_ID,
-- If using a single node Oracle deployment
"SERIAL#",
-- If using a clustered Oracle deployment, like Oracle Real Application Clusters
(SERIAL# || ',' || INST_ID) AS "SERIAL#",
AUDSID
-- If using a single node Oracle deployment
FROM V$SESSION
-- If using a clustered Oracle deployment, like Oracle Real Application Clusters
FROM GV$SESSION
WHERE
USERNAME='LOOKER';
CREATE OR REPLACE SYNONYM LOOKER.LOOKER_SESSION FOR LOOKER_SESSION;
GRANT SELECT ON LOOKER.LOOKER_SESSION TO LOOKER;
Cómo configurar agregaciones simétricas
Tu DBA de Oracle debe configurar la función LOOKER_HASH
para habilitar agregaciones simétricas. La función LOOKER_HASH
es un sinónimo de la función dbms_crypto.hash
de Oracle. La DBA también debe crear el sinónimo y los privilegios asociados. Los siguientes comandos suponen que el nombre del usuario de Looker es LOOKER
:
CREATE OR REPLACE FUNCTION LOOKER_HASH(bytes raw, prec number)
RETURN raw AS
BEGIN
return(dbms_crypto.HASH(bytes, prec));
END;
CREATE OR REPLACE SYNONYM LOOKER.LOOKER_HASH FOR LOOKER_HASH;
GRANT EXECUTE ON LOOKER.LOOKER_HASH TO LOOKER;
GRANT EXECUTE ON SYS.LOOKER_HASH TO LOOKER;
Según la configuración de tu base de datos de Oracle, el prefijo
SYS
puede serSYSDBA
,ADMIN
o innecesario.
Configura tablas derivadas persistentes
Para habilitar las tablas derivadas persistentes, otórgale al usuario de Looker los permisos UNLIMITED TABLESPACE
y CREATE TABLE
. Los siguientes comandos suponen que el nombre del usuario de Looker es LOOKER
:
GRANT UNLIMITED TABLESPACE TO LOOKER;
GRANT CREATE TABLE TO LOOKER;
Configura el cierre de consultas
Sigue estas instrucciones para configurar el cierre de consultas de una implementación tradicional de Oracle o de Amazon RDS.
Implementaciones tradicionales de Oracle
Para configurar el cierre de consultas en implementaciones tradicionales de Oracle, el DBA de Oracle debe crear el procedimiento LOOKER_KILL_QUERY
como sinónimo de ALTER SYSTEM KILL SESSION
. Para ello, ejecute el siguiente comando:
CREATE OR REPLACE PROCEDURE LOOKER_KILL_QUERY(p_sid in varchar2,
p_serial# in varchar2)
IS
cursor_name pls_integer default dbms_sql.open_cursor;
ignore pls_integer;
BEGIN
SELECT
COUNT(*) INTO ignore
-- If using a single node Oracle deployment
FROM V$SESSION
-- If using a clustered Oracle deployment, like Oracle Real Application Clusters
FROM GV$SESSION
WHERE
username = USER
AND sid = p_sid
-- If using a single node Oracle deployment
AND serial# = p_serial#;
-- If using a clustered Oracle deployment, like Oracle Real Application Clusters
AND (SERIAL# || ',' || INST_ID) = p_serial#;
IF (ignore = 1)
THEN
dbms_sql.parse(cursor_name,
'ALTER SYSTEM KILL SESSION '''
|| p_sid || ',' || p_serial# || '''',
dbms_sql.native);
ignore := dbms_sql.execute(cursor_name);
ELSE
raise_application_error(-20001,
'You do not own session ''' ||
p_sid || ',' || p_serial# ||
'''');
END IF;
END;
La DBA también deberá ejecutar estos comandos relacionados:
CREATE OR REPLACE SYNONYM LOOKER.LOOKER_KILL_QUERY FOR SYS.LOOKER_KILL_QUERY;
GRANT EXECUTE ON SYS.LOOKER_KILL_QUERY TO LOOKER;
Según la configuración de tu base de datos de Oracle, el prefijo
SYS
puede serSYSDBA
,ADMIN
o innecesario.
Implementaciones de Amazon RDS
En las implementaciones de Oracle en RDS de Amazon, se usa el procedimiento rdsadmin.rdsadmin_util.kill
para finalizar las consultas. Para usar este procedimiento, el usuario de la base de datos de Looker debe tener asignado el rol DBA
.
Dado que la razón social es un rol con una base de datos elevada, puedes omitir este paso y dejar de ejecutar consultas en Looker.
Para que el usuario de la base de datos de Looker pueda evaluar las capacidades de finalización, ejecuta el siguiente comando:
GRANT DBA TO LOOKER;
Crea la conexión de Looker a tu base de datos
En la sección Administrador de Looker, seleccione Conexiones y, luego, haga clic en Agregar conexión.
Completa los detalles de la conexión. La mayoría de las opciones de configuración son comunes en la mayoría de los dialectos de las bases de datos. Consulta la página de documentación Conecta Looker a tu base de datos para obtener más información. Las siguientes opciones de configuración son específicas de Oracle:
- Nombre: Especifica el nombre de la conexión. Así es como te referirás a la conexión en los proyectos de LookML.
- Dialect: Oracle.
- Usa TNS: Habilita las conexiones del sustrato transparente de red (TNS).
- Host: Es el nombre de host o el alias de TNS.
- Puerto: Puerto de la base de datos
- Base de datos: Es el nombre de la base de datos (si no usa TNS).
- Nombre del servicio: Es el nombre del servicio (si usas TNS).
- Nombre de usuario: Nombre de usuario de la base de datos o Base de datos temporal si las PDT están habilitadas.
- Contraseña: Contraseña de usuario de la base de datos
- Habilitar PDT: Usa este botón de activación para habilitar las tablas derivadas persistentes. Cuando las PDT están habilitadas, la ventana Connection muestra la configuración adicional de PDT y la sección Overrides PDT.
- Base de datos temporal: En Oracle, un usuario es un esquema, por lo que debe especificarse como el nombre del usuario de la base de datos. Para este ejemplo, usarías el valor de esquema temporal
LOOKER
. - Número máximo de conexiones del compilador de PDT: especifique la cantidad de compilaciones PDT simultáneas posibles en esta conexión. Configurar este valor demasiado alto puede afectar negativamente los tiempos de consulta. Para obtener más información, consulta la página de documentación Conecta Looker a tu base de datos.
- Parámetros adicionales de JDBC: Deje este campo en blanco, ya que Oracle no admite parámetros adicionales de JDBC.
- Programa de mantenimiento de grupos de datos y PDT: Es una expresión
cron
que indica cuándo Looker debe verificar los grupos de datos y las tablas derivadas persistentes. Obtén más información sobre esta configuración en la documentación Programa de mantenimiento de PDT y grupos de datos. - SSL: Marca esta opción para usar las conexiones SSL.
- Verificar SSL: Ignore este campo. Oracle usará el Truststore de Java predeterminado para verificar SSL.
- Cantidad máxima de conexiones por nodo: Esta configuración se puede dejar al valor predeterminado al principio. Obtén más información sobre esta configuración en la sección Max Connections per node de la página de documentación Conecta Looker a tu base de datos.
- Tiempo de espera del grupo de conexiones: Esta configuración se puede dejar en el valor predeterminado al principio. Obtén más información sobre esta configuración en la sección Tiempo de espera del grupo de conexiones de la página de documentación Conecta Looker a tu base de datos.
- Almacenamiento previo en caché de SQL Runner: Si quieres que SQL Runner no cargue previamente la información de la tabla y que solo se cargue la tabla, desmarca esta opción. Obtén más información sobre este parámetro de configuración en la sección Almacenamiento previo en caché de SQL Runner de la página de documentación Conecta Looker a tu base de datos.
- Zona horaria de la base de datos: Especifica la zona horaria que se usa en la base de datos. Deja este campo en blanco si no quieres que se convierta una zona horaria. Consulta la página de documentación Cómo usar la configuración de zona horaria para obtener más información.
Para verificar que la conexión se realice de forma correcta, haz clic en Probar. Consulta la página de documentación sobre cómo probar la conectividad de la base de datos para obtener información sobre la solución de problemas.
Para guardar esta configuración, haz clic en Conectar. En la sección Administrador de Looker, seleccione Conexiones y, luego, haga clic en Agregar conexión.
Compatibilidad de características
Para que Looker admita algunas funciones, tu dialecto de base de datos también debe admitirlas.
Oracle es compatible con las siguientes funciones a partir de Looker 23.8:
Atributo | ¿Es compatible? |
---|---|
Nivel de asistencia | Admitido |
Looker (Google Cloud Core) | Sí |
Agregaciones simétricas | Sí |
Tablas derivadas | Sí |
Tablas derivadas de SQL persistente | Sí |
Tablas derivadas persistentes nativas | Sí |
Vistas estables | Sí |
Asesinato de consultas | Sí |
Pivotes basados en SQL | Sí |
Zonas horarias | Sí |
SSL | Sí |
Subtotales | Sí |
Parámetros adicionales de JDBC | No |
Distingue mayúsculas de minúsculas | Sí |
Tipo de ubicación | Sí |
Tipo de lista | Sí |
Percentil | Sí |
Percentil distintivo | No |
Procesos de Show del ejecutor de SQL | Sí |
Tabla de descripción del ejecutor de SQL | Sí |
Índices de SQL Runner Show | Sí |
Ejecutor de SQL Select 10 | Sí |
Recuento de ejecutores de SQL | Sí |
Explicación de SQL | No |
Credenciales de OAuth | No |
Comentarios de contexto | Sí |
Agrupación de conexiones | No |
Bocetos de HLL | No |
Reconocimiento global | Sí |
PDT incrementales | No |
Milisegundos | Sí |
Microsegundos | Sí |
Vistas materializadas | No |
Distinto del recuento aproximado | No |