Publicado el Dejar un comentario

SQL básico. Introducción a las bases de datos relacionales.

A partir de esta fecha, empezaré a publicar entradas en el blog dedicadas especialmente a enseñar el lenguaje SQL que utilizan los motores de bases de datos relacionales. El primer grupo de entradas tendrá como título “SQL básico” y la descripción del tema a tratar. En este primer grupo veremos lo básico del lenguaje SQL. Más adelante y si el tiempo y la vida lo permiten, iré incluyendo grupos de temas un poco más avanzados del mismo lenguaje.

Esto viene a petición de unos colegas interesados en aprender este lenguaje para organizar su información electrónica en sus respectivos trabajos. Espero les sea útil tanto a ellos como al resto del público. Comenzaremos con conceptos muy breves de la teoría de las bases de datos.

¿Qué es una base de datos?

Una base de datos, en su definición más simple, sería un lugar donde guardamos información de forma clasificada y ordenada para en determinado momento obtener o extraer información de ella en forma fácil y rápida. Un archivero o conjunto de archiveros donde guardamos en forma ordenada y clasificada nuestros oficios o facturas es un ejemplo de una base de datos.

Con la llegada de las computadoras esas bases de datos dejaron de ser sólo papales y la información se volvió digital o electrónica. Se crearon varias formas de almacenar la información en formato digital, y es ahí donde aparecieron las bases de datos relacionales.

¿Qué es una base de datos relacional?

Con el tiempo las computadoras permitieron almacenar un gran volumen de información en poco espacio y permitieron analizar la información de forma más rápida y eficiente. Al inicio la información se comenzó a almacenar en las computadoras en forma de documentos de texto u hojas de cálculo que se organizaban por nombre en carpetas y subcarpetas.

Posteriormente se crearon los sistemas de bases de datos llamadas relacionales. Estos sistemas organizan la información en tablas, algo similar a los sistemas de hojas de cálculo (por ejemplo las de Excel). Las tablas están compuestas por columnas, también llamados campos y filas, también llamados registros. Dichas tablas también reciben el nombre de entidades. A diferencia de los sistemas de hojas de cálculo, las tablas se pueden relacionar con otras y conviven en un solo espacio, es por eso que reciben el nombre de relacionales esta bases de datos.

Organizando la información en una base de datos relacional.

Imaginemos que necesitamos ingresar los datos generales de todos los empleados de nuestra empresa a un sistema de base de datos relacional:

Crearíamos una tabla o entidad llamada EMPLEADO. A ésta tabla le agregaríamos las columnas o campos que representarían los datos generales que queremos almacenar del empleado. A cada columna le asignaríamos un nombre de acuerdo al dato general del empleado que va a contener, por ejemplo: CURP, NOMBRE, APELLIDO_PATERNO, APELLIDO_MATERNO, FECHA_NACIMIENTO, RFC, etc.

Enseguida agregaríamos los datos de cada uno de los empleados. El conjunto de datos de un empleado en particular representaría una fila o registro en la tabla o entidad EMPLEADO. Es decir, la tabla EMPLEADO tendría tantas filas o registros como empleados tengamos en nuestra empresa.

Gráficamente la tabla o entidad EMPLEADOS se vería como algo así:

En la imagen anterior, nuestra tabla EMPLEADO estaría compuesta por seis columnas o campos y contendría 2 registros o filas.

¿Pero cómo se crean las tablas y como se agregan , borran y modifican los registros que contienen? Bueno, es ahí donde entra el lenguaje SQL que lo explicaré en la siguiente sección.

¡Hasta la próxima!

IR A LA PAGINA DEL CURSO.

Publicado el Dejar un comentario

Linux Básico: cómo listar archivos.

En el sistema operativo Linux, se usa el comando ls desde una terminal, para listar los archivos contenidos en un directorio. El comando ls tiene varias opciones según cómo queramos mostrar el listado de archivos:

Listar archivos en Linux en formato largo.

Usamos la opción -l del comando ls para listar archivo en formato largo, es decir, para que muestre los permisos, el propietario, el grupo, el tamaño en bytes, la fecha de creación y el nombre del archivos entre otros datos. Por defecto los archivo son listados en orden alfabético:

Si deseamos listar los archivos en orden contrario al alfabético, agregamos la opción -r al comando -ls:

Listar archivos ordenados por fecha en Linux.

Si queremos mostrar los archivos ordenados por fecha de creación utilizamos la opción -t para indicarle que queremos ordenarlo por tiempo (fecha). Por defecto lista primero los archivos con fecha más reciente y al final, los más antiguos:

Para listar los archivos en el orden contrario es decir, primero los más antiguos y al final los más recientes, agregamos la opción -r antes vista.

Listar archivos ordenados por tamaño en Linux.

Ahora queremos ordenar el listado de archivos por tamaño. Para eso empleamos la opción -S del comando ls de la forma siguiente:

Por defecto, el orden del listado es del archivo de mayor tamaño al de menor tamaño. Si queremos lo contrario, primero los de menor tamaño y al final los de mayor tamaño, le agregamos la opción -r:

Listar todos los archivos de un directorio y sus subdirectorios en Linux.

Ahora queremos listar todos los archivos de un directorio como los archivos que se encuentran en sus subdirectorios. Para ello utilizamos la opción -R contenidos en el directorio:

Como se puede observar en la imagen anterior, además de listar los archivos del directorio, también muestra los archivos contenidos en los directorios uno y dos contenidos en el directorio actual. A este comando se le pueden agregar las opciones de ordenamiento que vimos anteriormente -t, -S y -r.

Listar los archivos ocultos en Linux.

Usamos la opción -a para listar todos los archivos incluyendo los archivos ocutos:

Como se puede observar en la imagen anterior, ahora aparecen además los archivos ocultos que antes no se mostraban, todos aquellos archivos que su nombre inicia con un punto: .bash_logout, .bash_profile, .bashrc, etc.

Existen más opciones del comando ls. Puede consultar esas opciones ejecutando el comando ls –help o man ls.

Espero les sirva esta entrada. ¡Hasta la próxima!

Publicado el Dejar un comentario

Obtener sesiones bloqueantes a través de consulta SQL en Oracle

Para obtener o saber si hay sesiones que estén ocasionando algún bloqueo en una base de datos Oracle 10g ejecutamos la siguiente consulta con un usuario con privilegios de administrador. En mi caso la estoy haciendo con el usuario SYS de Oracle:

SELECT
   blocking_session as "Id de la sesión bloqueante", sid as "Identificador de la sesión", 
   serial# "Numero de serie de la sesión", seconds_in_wait as "Segundos en espera"
FROM
   v$session
WHERE
   blocking_session is not NULL
ORDER BY
   blocking_session;

La columna “Id de la sesión bloqueante” nos mostrará el identificador de la sesión bloqueante. Esta columna, junto con el valor del “Número de serie de la sesión”, nos servirán para “matar” dicha sesión con el comando sql ALTER SYSTEM KILL SESSION.

¡Hasta pronto!