¿Por qué algunos países prosperan y otros no? Confianza social, tecnología y desarrollo

Imagen
Confianza social, tecnología y desarrollo: ¿por qué algunos países prosperan y otros no? En los últimos años he tenido la oportunidad de visitar varios países que han marcado profundamente mi forma de ver el desarrollo económico. He estado en Japón y visité Hiroshima, una ciudad que fue destruida por una bomba atómica y que hoy es una ciudad moderna y ordenada. También visité Corea del Sur, un país que hace pocas décadas era uno de los más pobres del mundo y que hoy es líder en tecnología e innovación. Y he visto Alemania, que después de dos guerras mundiales logró reconstruirse y convertirse nuevamente en una de las economías más fuertes del mundo. Estas experiencias generan una pregunta inevitable: ¿por qué algunos países logran reconstruirse y prosperar incluso después de enormes crisis, mientras que otras regiones con grandes recursos naturales siguen enfrentando dificultades para desarrollarse? Una posible respuesta está en un concepto muy estudiado en economía...

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

API de banxico para obtener tipo de cambio utilizando Javascript

Macro en Word para automatizar documentos: genera diplomas en segundos (con código VBA)