Crear una consulta de paso a través
Se aplica a
Puede usar Access como una aplicación front-end y, a continuación, vincular a tablas en un servidor back-end, como SQL Server. De forma predeterminada, la mayoría de las consultas se ejecutan localmente en el motor de base de datos ACE de Access. En algunos casos, Access puede ejecutar una consulta de forma remota en SQL Server, según la sintaxis SQL y otros factores. Para obtener más información, vea "Motor de base de datos JET versión 3.0: Conectividad ODBC" en Las notas del producto JET y ODBC redescubiertas.
A menudo, sin embargo, desea ejecutar explícitamente una consulta en un servidor de base de datos. Puede hacerlo para mejorar el rendimiento: los servidores de bases de datos tienen una mayor potencia de procesamiento que un equipo de escritorio y puede devolver un subconjunto más pequeño de datos a través de la conexión de red. Para ejecutar una consulta en un servidor de base de datos, use una consulta de paso a través que sea una instrucción Transact SQLTransact SQL (TSQL) que se conecta a SQL Server mediante un cadena de conexión ODBC. Por ejemplo, puede pasar una instrucción SELECT para devolver datos a una hoja de datos, formulario, informe o control de lista, ejecutar el equivalente de consultas de acción (instrucciones DML), llamar a procedimientos almacenados y realizar tareas administrativas (instrucciones DDL) (Lenguaje de definición de datos).
Nota Los resultados de una consulta de paso a través son de solo lectura. Para editar directamente los datos de una hoja de datos o formulario, cree una tabla vinculada a una vista indexada. Para obtener más información, vea Crear vistas indexadas.
- Conéctese a una base de datos del servidor.
Para obtener más información sobre cómo vincular a SQL Server, vea Importar o vincular a datos en una base de datos de SQL Server y Vincular o importar datos desde una base de datos de Azure SQL Server. - Seleccione Crear>diseño de consulta.
- Si es necesario, cierre el cuadro de diálogo Agregar tablas (Mostrar tabla en Access.
- SeleccionePaso a través dediseño>.
Access oculta la cuadrícula de diseño de la consulta y muestra la vista SQL. - Si no aparece la hoja de propiedades de la consulta, presione F4 para mostrarla.
- En la hoja de propiedades, haga clic en el cuadro de propiedades Odbc Connect Str y, a continuación, siga uno de estos procedimientos:
Para obtener un cadena de conexión:
- En el panel de navegación, haga clic con el botón derecho en una tabla vinculada al origen de datos deseado y seleccione Administrador de tablas vinculadas.
- En el cuadro de diálogo Administrador de tablas vinculadas , active la casilla del origen de datos y, a continuación, seleccione Editar.
- En el cuadro de diálogo Editar vínculo , copie el texto en el cuadro Cadena de conexión .
Escriba la consulta en la vista SQL.
Nota: Existen diferencias importantes entre Access SQL y SQL Server TSQL, especialmente con sintaxis, nombres de función y argumentos de función. Para más información, vea Comparar Access SQL con SQL Server TSQL.
Propina Cree la consulta TSQL en SQL Server Management Studio primero y, a continuación, copie y pegue la consulta SQL en la vista SQL. Esto garantiza que la consulta tenga la sintaxis correcta. Si no tiene acceso cómodo a una base de datos de SQL Server, considere la posibilidad de instalar Microsoft SQL Server Express edición en el escritorio, que admite hasta 10 GB y es una forma gratuita y sencilla de realizar y comprobar la migración.Considere la posibilidad de establecer propiedades relacionadas adicionales:
Registros devueltos Algunas instrucciones SQL devuelven registros, como SELECT, y otros no, como UPDATE. Si la consulta devuelve registros, establezca esta propiedad en Sí; si la consulta no devuelve registros, establezca esta propiedad en No.
Nota Las consultas de paso a través pueden devolver varios conjuntos de resultados, pero en una variable de hoja de datos, formulario, informe o conjunto de registros, solo se usa el primer conjunto de resultados. Para recuperar varios conjuntos de resultados, use una consulta de creación de tabla como se muestra en el ejemplo siguiente:SELECT <pass-through query name>.* INTO <local table name> FROM < pass-through query name >Debe usar el asterisco (*) porque cada conjunto de resultados puede tener columnas diferentes. Cada conjunto de resultados se guarda en una tabla independiente y los números se anexan a los nombres de tabla local en consecuencia. Por ejemplo, si se devuelven tres conjuntos de resultados, los nombres de tabla serían: <nombre> de tabla local, <nombre>de tabla local 1, <nombre>de tabla local 2.
Mensajes de registro Especifique si se deben devolver mensajes de la base de datos SQL en una tabla de mensajes de Access. El nombre de tabla tiene el formato, nombre de usuario – nn, donde nombre de usuario es el nombre de inicio de sesión para el usuario actual y nn es un número que comienza en 00.
Tiempo de espera de ODBC Especifique el número de segundos de espera antes de que se produzca un error de tiempo de espera al ejecutar una consulta. El valor predeterminado es 60 segundos. Es posible que haya retrasos debido al tráfico de red o al uso intensivo del servidor de bases de datos.
Registros máximos Especifique el número máximo de registros que se devolverán. Es posible que tenga recursos limitados del sistema o que desee probar los resultados con solo una pequeña cantidad de datos.
Cuando termine de escribir la consulta, seleccioneEjecutardiseño>. La consulta se envía al servidor de bases de datos para su procesamiento.
