Lancé Excel Z: un entrenamiento práctico para aprender Excel desde cero

Imagen
Hoy quiero compartir un proyecto que estuve desarrollando con mucho cuidado aprender Excel desde cero jugando y practicando: Excel Z ⚡ Excel Z es un entrenamiento práctico para aprender Excel desde cero, a través de retos visuales y ejercicios reales. No es un curso tradicional lleno de teoría. La idea es aprender haciendo, paso a paso, como un entrenamiento mental. ¿Qué incluye Excel Z (Retos 1 al 3)? ✔ Manual en PDF con los retos ✔ Ejercicios prácticos en Excel, plantilla de Excel ✔ Imágenes ilustradas de cada reto ✔ Un mazo imprimible tipo cartas para entrenar sin pantalla Está pensado para: - Personas que quieren mejorar en Excel - Maestros que buscan material didáctico - Estudiantes - Oficinistas - Personas que siempre dijeron “Excel no es lo mío” El contenido está completamente en español. 👉 Puedes ver el producto aquí: Excel Z Retos 1 al 3 Este es solo el inicio del proyecto, más retos y niveles vendrán después. Gracias por leer y por apoyar proyectos educativos independie...

Como ejecutar SQL desde Tareas Programadas de Windows

Bienvenidos a este blog, esta semana les quiero compartir otro ejemplo de archivos BAT o Batch en Windows para ejecutar una consulta a una base de datos SQL con la instrucción sqlcmd y poder ejecutar tareas programadas en sql server desde las tareas programadas de Windows.

El comando sqlcmd es de Microsfot y nos ayuda para ejecutar consultas desde un archivo esta es la definición que da Microsoft

La utilidad sqlcmd es una utilidad de la línea de comandos para la ejecución ad hoc e interactiva de instrucciones y scripts de Transact-SQL y para la automatización de tareas de scripting de Transact-SQL. Para usar sqlcmd interactivamente, o para compilar archivos de script que se ejecutan mediante sqlcmd, los usuarios deben estar familiarizados con Transact-SQL. La utilidad sqlcmd se usa normalmente de las formas siguientes:

Ejemplo:

Objetivo: Ejecutar un query a una base de datos para obtener las facturas timbradas a clientes y crear un archivo csv de salida y alojarlo en una carpeta

Código

Necesitamos 2 archivos

Uno que sea el archivo BAT en mi caso lo llame sqltimbrados.bat  y dentro las siguientes lineas

sqlcmd -i C:\CFDIxml\SAT3.3\UUID_QAD\sqljob.sql -o W:\einvoicemx\folios.csv
if errorlevel 1  

echo == An error occurred


la primera linea es para que llame el comando sqlcmd al archivo que contiene el query o consulta a sql y con el parametro -o le indicamos que deje la salida al archivo folios.csv en una unidad mapeada en la computadora así que no solo pueden dejar archivos en su propia computadora puede ser en alguna otra maquina en la que estén en red. 

Archivo 2 es donde esta la consulta a la base de datos el archivo lo llame sqljob.sql y contiene lo siguiente

SELECT FolioSAT, ',' ,
  (CONVERT(varchar(10),year(FechaComprobante))+'/'+ serie + folio) as factura
FROM [Comprobante] 
WHERE esprueba = 0 AND
( confirmacion IS NULL OR 
confirmacion = '' )
;
UPDATE [Comprobante] SET Confirmacion = 'EXPORTED-TO-QAD'
WHERE esprueba = 0 AND 
AND  ( confirmacion IS NULL OR 
confirmacion = '' ) 

;




En mi consulta esta dividido en 2 partes, la primera es el query para obtener los datos y en la segunda un update para marcar que registros leyó el query para no volverlo a tomar.

En el primer select obtengo 3 columnas, el folio del SAT, el folio de la factura como lo requiero que es concatenando o uniendo el Año de timbrado más "/" una diagonal , mas la serie, mas el folio y a ese campo le llamo Factura, el archivo de salida se ve así





Adicional a estos 2 archivos, configure una tarea programada para ejecutar el archivo bat de manera diaria, de esta forma tengo un proceso automático, que podría haberse realizado también con un store procedure en la base de datos y crear un Job en la Base de datos, pero como tengo SQL Server Express no tengo la función de Job, así que me parece una muy buena alternativa la que les mostré. 



Usos de este script, puede ser para generar respaldos de la base de datos, para enviar información a otro sistema mediante una red mapeada, generar consulta de información para reportes. 

No olvide compartirnos y seguirnos en este blog, en Facebook.

Otro ejemplos de SQL en este blog

Mas ejemplos de Batch

Comentarios

  1. Muy buena la explicación, gracias
    Una pregunta y si preciso conectarme a una base que esta en otra maquina y le tengo que dar usuario y clave de la base para conectarme a la misma, como sería? Gracias

    ResponderBorrar
  2. Podrías privar en el archivo .sql en la primer línea
    DESKTOP-5K4TURF\SQLEXPRESS -U usuario -P
    Password
    Después tus querys

    ResponderBorrar

Publicar un comentario

Dejanos tus dudas y comentarios

🚀 Mantener este blog funcionando requiere tiempo y café. ¡Puedes contribuir con uno aquí!

Entradas más populares de este blog

Guía Práctica: Ejemplo Completo de ASPX para Desarrolladores Web

📊 Automatiza tu trabajo: Convierte tablas de Word a Excel con una macro

Ejemplo de Macro en Word para Automatizar Documentos