Conversión de cadena de texto a DATETIME

Consultas que convierten y manipulan un objeto DATETIME de SQL Server

Una de las funcionalidades que , aunque en ocasiones son un dolor de cabeza, son interesantes de conocer, ya que nos permiten manejar de mejor forma la información que tenemos en base de datos, ya sea para mostrar por pantalla o para la exportación de datos para ser consumidos por alguna persona, y siempre es bueno que lo entreguemos la información en el formato más natural posible, ya que la gran mayoría de los usuarios son personas comunes y corrientes y no seres sobrenaturales a-dimensionales como los informáticos que entendemos el glorioso valor de un TIMESTAMP. Es por ello que presento la siguiente funcionalidad que he ocupado por mucho tiempo y no había notado que no lo había compartido, es por ello que les presento una pequeña porción, pero muy útil, del uso de unas funcionalidades muy básicas en el manejo de fechas usando como fuente una fecha que viene en cadena de texto, esto porque en muchas ocasiones me he topado con el hecho que los datos vienen desde la fuente en String del tipo YYYYMMDD, pero, calma, que no panda el cúnico… porque hay solución.

Para la transformación del dato de texto a Datetime usé la función CAST de SqlServer y luego de transformarlo a fecha, le resté un mes con la función DATEADD y finalmente le di un formato como yo necesito. Sin más acá les dejo el código sencillo y espero que más que útil para más de alguno.

-- Obtención de un objeto DATETIME desde una cadena de texto

SELECT CAST('20200101' AS DATETIME)  AS fecha

-- resultado 
-- 01/01/2020 0:00:00


-- Resta de un mes a la fecha obtenida desde una cadena de texto

SELECT dateadd(month, -1, CAST('20200101' AS DATETIME))  AS fecha

-- resultado
-- 01/12/2019 0:00:00
                               
                               
-- Formatea una fecha a un patrón de fecha definido por el usuario
                               
SELECT format( dateadd(month, -1, CAST('20200101' AS DATETIME)), 'dd-MM-yyyy HH:mm:ss')  AS fecha

-- resultado
-- 01/12/2019 0:00:00

Crear tablas temporales SQLServer

Ejemplo para crear tablas temporales para la base de datos SQLServer (versión 2012) pero que tanbién sirve para versiones más actualizadas

En muchas ocasiones para resolver un problema en SQLServer en el cual debo extraer información desde una o varias tablas de la base de datos, necesito crear tablas temporales dentro de los procedimientos almacenados, esto para el cruce de información más ordenado y eficiente. a continuación les dejo un ejemplo de script sencillo que tiene por objetivo la creación de una tabla temporal que implementa unos indices que son necesarios para que el motor de base de datos busque al información dentro de esta tabla de forma rápida y eficiente.

CREATE TABLE #tabla_temporal (
	 id_tabla BIGINT
	,cd_columna_01 BIGINT
	,gl_columna_02
)
CREATE NONCLUSTERED INDEX idx_tabla_temporal ON #tabla_temporal ([id_tabla])


-- Otras formas de definir indices

-- Indice no ordenado
CREATE INDEX idx_tabla_temporal ON #tabla_temporal (id_tabla);

-- Indice a partir de 2 columnas
CREATE UNIQUE INDEX idx_tabla_temporal ON #tabla_temporal (id_tabla asc, cl_columna_01 asc)

Lista de tablas y SPs SQL Server

Lista de tablas y Stored Procedures de un esquema en un servidor SQL Server versión 2012+

Estas simples instrucciones retorna una lista de las tablas y procedimientos almacenados en un esquema particular de un esquema Sql Server en su versión 2012, el código es el siguiente

-- Lista de tablas
SELECT * FROM INFORMATION_SCHEMA.TABLES

-- Lista de SP's
SELECT * FROM INFORMATION_SCHEMA.routines where routine_type = 'PROCEDURE'

-- Lista de tablas con las columnas y sus descripciones
SELECT	sys.objects.name AS TableName, 
		sys.columns.name AS ColumnName,
		ep.value AS Description
FROM sys.objects
INNER JOIN sys.columns ON sys.objects.object_id = sys.columns.object_id
CROSS APPLY fn_listextendedproperty(default, 
									'SCHEMA', 
									schema_name(schema_id),
									'TABLE', 
									sys.objects.name, 
									'COLUMN', sys.columns.name) ep
ORDER BY sys.objects.name, 
		 sys.columns.column_id
		 
		 
-- Ejemplo listado de tablas para borrar contenido
SELECT 'DELETE FROM ' + TABLE_NAME 
  FROM INFORMATION_SCHEMA.TABLES 
 WHERE TABLE_NAME LIKE 'SCC_%'

Cálculo de fechas SQL Server

Ejemplo simple para el cálculo de diferencias en fechas

Acá hay una consulta SqlServer para el cálculo de diferencias de fechas sql, el rango de la diferencia está en días minutos y segundos, esto lo uso particularmente para cuando necesito saber el tiempo que ha pasado desde que un dato fue insertado o actualizado hasta la fecha actual.

Como dato adicional puedes consultar esta publicación para el formateo de registros del tipo datetime https://cesarg.cl/formateo-de-una-fecha-en-sql-server/

Este cálculo de fechas lo realicé en una query de SQL Server 2012, es muy sencilla y tiene como base de cálculo la fecha y hora actual del servidor, por otro lado hay que considerar que la unidad que usa sql server para restar o sumar periodos a una fecha es el día, entendiendo esto, por lo que para restar periodos inferiores a días, ejemplo: horas, minutos y segundos se debe dividir 1(día) por 24, 2460 y 2460*60 respectivamente.

El resultado de esta consulta sería algo como esto

Espero que les sea útil y cualquier comentario o mejora no dudes en realizarlo.

Script SQL de tablas de Región, Provincias y Comunas de Chile

Script para Mysql con las tablas pobladas con las regiones, provincias y comunas de Chile, actualizado al 2017

Hace varios años (2007) tuve que hacer una formulario con los famosos combos Región-Privincia-Comuna, lamentablemente por esos años, no habian script o eran bastante escasos por lo que me puse a hacer uno a pulso, después de varios años hemos tenido cambios en nuestra división política, por lo que he tenido que actualizarlo, ahora re-hice el script con los datos de gobierno, específicamente de la página de Subdere actualizada el 2011 en http://www.subdere.cl/documentacion/regiones-provincias-y-comunas-de-chile, está hecha para una base de datos MySql. espero que les sea de utilidad!!

Acá dejo el ZIP con los script reg_pro_com.sql