Guías de Make it Real
  • Introduction
  • Preparación
    • Conceptos básicos
    • El editor de texto
    • La línea de comandos
    • Git y Github
  • Git
    • Instalación y configuración
    • Conceptos y comandos esenciales
    • Ignorando archivos y carpetas
    • Trabajando con ramas
    • Repositorios remotos
    • Etiquetas
    • Reescribiendo la historia
    • Stashing
    • Github
  • HTML y CSS
    • Introducción a HTML
    • Introducción a CSS
    • Más elementos de HTML
    • Tablas
    • Formularios
    • El modelo de caja en CSS
    • Fondos (backgrounds)
    • Posicionamiento
    • Selectores CSS
    • Bordes, sombras y gradientes
    • Media Queries
    • Unidades en CSS
    • Flexbox
  • Bootstrap 3
    • Primeros pasos
    • Elementos básicos de HTML
    • Componentes
    • La grilla
    • Personalizando Bootstrap
    • Utilizando plantillas
  • Bootstrap 4
    • Primeros pasos
    • Elementos básicos de HTML
    • Componentes
    • La grilla
    • Clases utilitarias
    • Personalizando Bootstrap
  • Ruby
    • Primeros pasos
    • Tipos y operadores
    • Variables y entrada de usuario
    • Condicionales
    • Ciclos
    • Arreglos
    • Más cadenas de texto
    • Hashes
    • Métodos
    • Manipulación de archivos
    • Gemas
  • Programación Orientada a Objetos en Ruby
    • Clases y objetos
    • Métodos y atributos de clase
    • Herencia
    • Módulos
    • Excepciones
  • JavaScript I
    • Primeros pasos
    • Tipos y operadores
    • Variables
    • Condicionales
    • Ciclos
    • Arreglos
    • Más cadenas de texto
    • Funciones
    • Objetos literales
    • Manipulación de archivos
  • JavaScript en el navegador
    • Primeros pasos
    • Manipulando HTML
    • Escuchando eventos
    • Local Storage
    • History API
    • Canvas
    • Notificaciones Web
    • Audio y Video
    • Arrastrar y soltar
    • JSON
    • Realizando peticiones HTTP
  • jQuery
    • Primeros pasos
    • Manipulando HTML
    • Escuchando eventos
    • Plugins
    • Realizando peticiones con AJAX
  • JavaScript II
    • Prototipos
    • Librerías (Node.js)
    • ES6
    • Uso de this (call, apply, bind)
    • Programación funcional
    • Scope, hoisting, closures
    • Programación asincrónica
    • Testing
  • HTTP y Sinatra
    • Primeros pasos con Sinatra
    • El protocolo HTTP
    • Rutas
    • Formularios
    • Cookies y sesión
  • Bases de datos
    • Bases de datos relacionales
    • SQL
    • DDL
    • MongoDB
  • Ruby on Rails I
    • Primeros pasos
    • Arquitectura
    • Rutas
    • Layouts y rendering
    • ActiveRecord - Modelos
    • ActiveRecord - Migraciones
    • ActiveRecord - Validaciones
    • ActiveRecord - Asociaciones
    • ActiveRecord - Scopes
    • ActiveRecord - Callbacks
    • Recursos REST
    • Formularios
    • Autenticación con Devise
    • Sass y Bootstrap
    • Envío de correos
    • Carga de imágenes
    • Seeds
    • Heroku
  • Ruby on Rails II
    • Usando JavaScript (y jQuery) en Rails
    • Testing en Ruby
    • Testing en Rails
    • Creando una Web API
    • Web Sockets
  • Express.js
    • Primeros Pasos
    • El protocolo HTTP
    • Rutas
    • Vistas
    • Middlewares y manejo de errores
    • Formularios
    • Cookies y sesión
  • Express.js II
    • Mongoose
    • Web Sockets
    • Autenticación
    • Envío de correos
    • Cargar imágenes
    • Deployment
    • Testing
    • Creando una Web API
  • React
    • Primeros pasos
    • JSX
    • Componentes
    • Más sobre estado
    • Formularios
    • Peticiones HTTP con Axios
    • React Hooks
    • React Context
    • React Bootstrap
    • React Router
    • Carga de Imágenes
    • Testing
    • Estructura de carpetas
    • Componentes de clase
  • Redux
    • Primeros pasos
    • Action creators
    • Usando la librería react-redux
    • Middlewares
    • Operaciones asincrónicas con redux-thunk
    • Combinando funciones reductoras
    • Testing
    • Redux Tool Kit
  • Algoritmos
    • Describiendo un algoritmo
    • Complejidad (Big-O)
    • Estructuras de datos
    • Recursión
    • Ordenamiento
    • Búsqueda
    • Programación dinámica
  • Python
    • Primeros Pasos
    • Tipos y Variables
    • Funciones
    • Control de Flujo
    • Listas
    • Ciclos
    • Diccionarios, Tuplas y Sets
  • NumPy
    • Primeros Pasos
    • Arreglos
    • Arreglos Multidimensionales
    • Estadística con NumPy
    • Distribución Estadística
  • Pandas
    • Primeros Pasos
    • Inspección y Selección de Datos
    • Modificando Dataframes
    • La Función Lambda
    • Aggregates en Pandas
    • Múltiples Tablas
Powered by GitBook
On this page
  • Creando bases de datos con CREATE DATABASE
  • Creando tablas con CREATE TABLE
  • Tipos de datos
  • Llaves foráneas
  • Eliminando tablas con DROP TABLE
  • Cambiando tablas con ALTER TABLE
  1. Bases de datos

DDL

PreviousSQLNextMongoDB

Last updated 2 years ago

DDL nos permite crear y definir la estructura que va a tener cada base de datos.

DDL tiene más diferencias que SQL entre los diferentes motores de bases de datos. Los ejemplos que vamos a ver a continuación aplican únicamente para .

Las operaciones más comunes con DDL son:

  • Crear bases de datos con CREATE DATABASE;

  • Crear tablas con CREATE TABLE.

  • Eliminar tablas con DROP TABLE.

  • Cambiar tablas con ALTER TABLE.

Creando bases de datos con CREATE DATABASE

La sintaxis para crear una base de datos es la siguiente:

CREATE DATABASE <nombre>;

Por ejemplo:

CREATE DATABASE myhotels;

Creando tablas con CREATE TABLE

La sintaxis más básica para crear una tabla es (asumiendo que queremos tener una llave primaria llamada id que sea autonumérica):

CREATE TABLE <nombre> (
  id serial PRIMARY KEY,
  <columna2> <tipodedato>,
  ...
);

Por ejemplo:

CREATE TABLE hotels (
  id serial PRIMARY KEY,
  name varchar(255) NOT NULL,
  stars int
);

El NOT NULL al final del campo name le dice a PostgreSQL que ese campo no acepta valores nulos.

Tipos de datos

PostgreSQL tiene una gran variedad de tipos de datos pero vamos a ver los principales:

  • integer o int: campo numérico.

  • decimal: número con decimales.

  • serial: numérico autoincremental.

  • varchar: texto con límite.

  • text: texto sin límite.

  • timestamp: fecha y hora.

  • date: fecha sin hora.

  • time: hora sin fecha.

  • boolean o bool

Existen muchos más tipos pero estos son los que se usan la mayor parte del tiempo y se encuentran en la mayoría de motores.

Llaves foráneas

Para crear una llave foránea puedes utilizar la palabra clave REFERENCES como en el siguiente ejemplo:

CREATE TABLE rooms (
  id SERIAL PRIMARY KEY,
  hotel_id int REFERENCES hotels (id) ON DELETE CASCADE,
  number varchar(10)
);

REFERENCES hotels (id) crea la llave foránea.

ON DELETE CASCADE es opcional y le dice a la tabla que cuando eliminen un registro en hotels, también elimine todos los registros relacionados en rooms.

Eliminando tablas con DROP TABLE

La sintaxis para eliminar una tabla es:

DROP TABLE <tabla>;

Por ejemplo:

DROP TABLE rooms;

Cambiando tablas con ALTER TABLE

La sintaxis de ALTER TABLE cambia dependiendo de los que queramos hacer. Veamos las tres tareas más comunes:

Para agregar una columna a una tabla utilizamos la siguiente sintaxis:

ALTER TABLE <tabla> ADD <columna> <tipodedatos> <restricciones>;

Para eliminar una columna de una tabla utilizamos la siguiente sintaxis:

ALTER TABLE <tabla> DROP COLUMN <columna>;

Para modificar el tipo de datos de una columna utilizamos la siguiente sintaxis:

ALTER TABLE <tabla> MODIFY <columna> <tipodedatos> <restricciones>;

Ejemplos:

ALTER TABLE hotels ADD address varchar(255) NOT NULL;
ALTER TABLE hotels DROP COLUMN address;
ALTER TABLE hotels MODIFY address varchar(100) NOT NULL;
PostgreSQL