Aprende SQL
Aprende SQL
Con MySQL y MariaDB
Sobre este libro
Aprende SQL con MySQL y MariaDB combina todos mis años de experiencia en la administración de sistemas de bases de datos SQL y tiene por objetivo enseñarte a dominar los comandos SQL y los principios fundamentales de base de datos.
En los capítulos de esta obra encontrarás de manera detallada una gran cantidad de respuestas a preguntas comunes sobre el manejo de base de datos, todo esto con un enfoque sencillo y sumamente práctico.
Este material cuenta con la confianza y el respaldo de Styde. Luego de adquirir una copia, por favor envíanos un email a admin+sql@styde.net con los datos de tu compra y te enviaremos una invitación a Slack donde podrás hacer consultas y compartir con otros integrantes de la comunidad, de manera de que puedas mejorar tus habilidades hasta convertirte en todo un profesional en el manejo de bases de datos.
Tabla de contenido
- Prefacio
-
Introducción
- ¿Cómo leer este libro?
- Convenciones usadas en el libro
- Ponerse en contacto
-
Visión General
- Arquitectura
- Componentes de MySQL
- Convenciones de nombres de bases de datos
-
Instalación del software
- Dónde buscar el software del servidor
- Instalar desde paquetes
- Compilar e Instalar desde código fuente
- ¿Cuál es más recomendable?
- XAMPP y software de terceros
- Comprobar si los servicios MariaDB y APACHE están habilitados
- Habilitando los servicios manualmente
- Habilitando los servicios automáticamente
-
Configuración
- Cómo evitar los accesos no seguros
-
Administrar MySQL/MariaDB con un usuario diferente de
root
- Clientes para MySQL/MariaDB
-
Creación de una base de datos
- Estableciendo una conexión a tu servidor de base de datos
- Identificando una base de datos
- Creando la base de datos en MySQL
- ¿Cómo eliminar una base de datos?
- Volviendo a crear el ejemplo
- Definición del conjunto de caracteres y criterios de ordenamiento
- Estableciendo la base de datos predeterminada
-
Creación de tablas
- Definiendo la estructura de una tabla
- Mostrar las tablas pertenecientes a una base de datos
- Visualizar la estructura de una tabla
- Otro ejemplo sencillo de definición de tabla
- Una breve manipulación de tablas
- Valores por defecto ocultos en una tabla
-
Modificación de la estructura de las tablas
- Haciendo respaldos antes de modificar tablas en sistemas de producción
- Modificaciones que afectan tablas
- Modificaciones que afectan índices
- Eliminando una tabla
-
Insertando datos en tablas
-
Sintaxis del comando
INSERT INTO
- Insertar especificando la lista de campos
- Insertando múltiples registros
-
Usar
INSERT INTO
sin especificar el encabezado de tabla - Insertar valores por defecto de una columna
- Insertando los valores de la clave primaria
- Claves foráneas y tablas relacionadas
- Cómo definir una restricción de clave foránea
- Insertar datos en tablas relacionadas
- Consultando la información relacionada
-
Prioridad de ejecución durante el uso del comando
INSERT
-
Sintaxis del comando
-
Selects sobre tablas
- Scripts de SQL
- Cómo ejecutar un script de SQL
- Contenido del script capitulo_8.sql
- Copiando las tablas necesarias
- Verificando la estructura de las tablas agregadas con el script capitulo_8.sql
-
El comando
SELECT
..FROM
tabla -
Cláusula
LIMIT
- Especificando una lista de campos
-
Cláusula
WHERE
-
Ordenamiento sobre el conjunto resultante,
ORDER BY
- Consultando tablas que tienen claves foráneas
- Combinación de tablas.
- Resumen de cálculos a nivel horizontal y vertical.
- Agrupamiento
- Otras expresiones de comparación.
- operador LIKE.
-
Índices
- Justificación del uso de índices
- Operaciones donde MySQL hace uso de índices.
- Cantidad de columnas por índices
- Indices prefijo
-
Indices
FULLTEXT
- Indices de múltiples columnas
- Cómo se crean los índices
- Añadir claves foráneas en la creación de las tablas
- Cómo añadir claves foráneas con una modificación de la estructura de la tabla
- Eliminando claves foráneas
-
Uso del comando
CREATE INDEX
para crear los otros tipos de índices.
-
Actualizando datos
-
Sintaxis básica del comando
UPDATE
-
Restringiendo el comando
UPDATE
con la cláusulaWHERE
-
Ordenamiento de las actualizaciones con la cláusula
ORDER BY
-
Limitando las actualizaciones con la cláusula
LIMIT
- Actualización con múltiples tablas
-
Sintaxis básica del comando
-
Eliminando datos
-
Sintaxis del comando
DELETE
para una sola tabla - Ejemplo de eliminación de un registro
- Eliminando filas en múltiples tablas
-
Sintaxis para un
DELETE
en múltiples tablas -
Ejemplo con el comando
DELETE
para múltiples tablas
-
Sintaxis del comando
-
Operadores relacionales
- ¿Cuáles son estos operadores?
-
Restringir o
WHERE
- Proyectar o especificar una lista de campos
- Registros duplicados
- Producto cartesiano
- Unión
-
Renombrar o
AS
-
Intersección o
INTERSECT
-
Diferencia o
EXCEPT
-
Funcionamiento interno del comando
SELECT
-
La cláusula
SELECT
-
La cláusula
FROM
-
La cláusula
WHERE
-
La cláusula
GROUP BY
- Cláusula HAVING
- Consideraciones de la omisión de cláusulas
-
Ejemplo del funcionamiento de un comando
SELECT
-
La cláusula
-
Joins
-
El Operador
JOIN
-
Cláusula
JOIN
..ON
- Joins que utilizan campos comunes nombrados idénticamente
-
Cláusula
JOIN
..USING
-
Cláusula
NATURAL JOIN
-
Reescribiendo algunos ejemplos anteriores con cláusulas
JOIN
-
Cláusula
LEFT JOIN
- Actualización de tablas mediante joins
-
Revirtiendo el cambio de nombre de
category_id
porid
en la tablacategories
-
Eliminando filas en múltiples tablas usando
JOIN
-
Cláusula
RIGHT JOIN
-
El Operador
-
Subconsultas
- Subconsulta escalar
- Subconsultas de columna
- Subconsultas de tabla
-
Funciones para manejo de cadenas de caracteres
- Formateando cadenas de caracteres
- Concatenando cadenas
- Concatenar especificando un separador
- Formateando un número
- Convirtiendo cadenas en mayúsculas o minúsculas
- Eliminación de espacios redundantes
- Relleno de cadenas de caracteres
- Extrayendo texto
- Búsqueda de cadenas
- Longitud de cadenas
- Comparación y búsquedas de cadenas de caracteres
- Reemplazando e insertando dentro de cadenas de caracteres
- Conversiones de tipos de cadenas
- Compresión de cadenas
-
Funciones para manejo de fechas y horas
- Tipos de datos temporales
- Valores no válidos
-
Propiedades de inicialización y actualización automática para
TIMESTAMP
yDATETIME
- Funciones que proporcionan la fecha y hora actual
- Funciones que proporcionan partes de fecha a partir de la fecha actual
-
Tiempo de tipo
UNIX
- Descomponer una fecha completa en sus componentes
- Formatear la fecha y hora
- Ajuste de la zona horaria
- Sumar o restar intervalos de tiempo a las fechas
- Determinar la cantidad de segundos en una hora dada
- Períodos
- Comparación de fechas y horas
-
Funciones de agrupamiento y cálculos horizontales
- Qué es una función de agrupamiento
- Efectuando un conteo de registros
- Efectuando la sumatoria de los campos
- Determinar el promedio
- Obtención de valores mínimos y máximos
- Concatenando grupos
- Cálculos horizontales y las funciones numéricas
- Redondeo de cifras
- Truncar números
- Eliminación de números negativos
- Generación de números aletorios
-
Creación de cuentas de usuario y privilegios
- Algunos aspectos de seguridad
- El sistema de privilegio de acceso de MySQL
- Privilegios de acceso de las cuentas
- Especificación de los nombres de las cuentas
- Verificación de la conexión
- Verificación de requerimientos
- Cambios de privilegios
- Manejo de cuentas de usuario
- Añadiendo cuentas de usuario
- Visualizando los privilegios asignados
- Cuentas anónimas
- Remover cuentas de usuario
- Restringiendo el acceso
- Restringiendo a nivel de columnas
- Cambio de contraseñas
- Renombrar una cuenta de usuario
- Roles de usuario
-
Respaldando y restaurando la base de datos
- ¿Qué significa respaldar y restaurar una base de datos?
- Respaldando información usando MySQL o MariaDB
- Respaldando todas las bases de datos
- Respaldar sólo algunas bases de datos
- Creando una respaldo de base de datos en blanco
- Respaldando una tabla
- ¿Porque es necesario prepararnos para recuperar una bases de datos?
- Restaurando desde un respaldo
Leanpub incondicional, sin riesgo, 100% de felicidad garantizada
Durante los primeros 60 días de compra, puedes obtener un reembolso del 100% de cualquier compra Leanpub, en dos clics. Procesamos las restituciones manualmente, así que puede tomarse unos días en aparecer. Véase términos completos.
Que estés bien. Haz el bien.
Authors have earned$11,845,077writing, publishing and selling on Leanpub, earning 80% royalties while saving up to 25 million pounds of CO2 and up to 46,000 trees.
Learn more about writing on Leanpub
Actualizaciones gratis. Libre de DRM.
¡Si compras un libro Leanpub obtienes actualizaciones gratis siempre y cuando el autor actualice el libro! Varios autores usan Leanpub para publicar sus libros en progreso mientras los escriben. Todos los lectores obtienen actualizaciones gratis, independientemente de cuándo compraron el libro o cuánto pagaron (incluyendo si fue gratis).
La mayoría de los libros Leanpub se encuentran disponibles en PDF (para computadores) y EPUB (para teléfonos, tabletas, y Kindle). Los formatos que un libro incluye se muestran en la esquina superior derecha de esta página.
Finalmente, los libros Leanpub no tienen ninguna de las cosas sin sentido sobre protección de copia DRM, así que puedes leerlos fácilmente en cualquier dispositivo que se soporta.
Aprende más sobre los formatos de Leanpub y dónde puedes leerlos
Top Books
The Hitchhiker's Guide to DFIR: Experiences From Beginners and Experts
Barry Grundy, Tristram, John Haynes, ApexPredator, Andrew Rathbun, Kevin Pagano, Victor Heiland, Nisarg Suthar, Guus Beckers, and Jason WilkinsA first-of-its-kind crowdsourced Digital Forensics and Incident Response (DFIR) book by the Digital Forensics Discord Server members to share knowledge!
OpenIntro Statistics
David Diez, Christopher Barr, Mine Cetinkaya-Rundel, and OpenIntroA complete foundation for Statistics, also serving as a foundation for Data Science.
Leanpub revenue supports OpenIntro (US-based nonprofit) so we can provide free desk copies to teachers interested in using OpenIntro Statistics in the classroom and expand the project to support free textbooks in other subjects.
More resources: openintro.org.
Ansible for DevOps
Jeff GeerlingAnsible is a simple, but powerful, server and configuration management tool. Learn to use Ansible effectively, whether you manage one server—or thousands.
Maîtriser Apache JMeter
Philippe Mouawad, Bruno Demion (Milamber), and Antonio Gomes RodriguesToute la puissance d'Apache JMeter expliquée par ses commiteurs et utilisateurs experts. De l'intégration continue en passant par le Cloud, vous découvrirez comment intégrer JMeter à vos processus "Agile" et Devops.
If you're looking for the newer english version of this book, go to Master JMeter : From load testing to DevOps
Software Architecture for Developers
Simon BrownA developer-friendly, practical and pragmatic guide to lightweight software architecture, technical leadership and the balance with agility.
Functional Event-Driven Architecture
Gabriel VolpeExplore the event-driven architecture (EDA) in a purely functional way. Learn to design and develop distributed systems that scale. Identify common design patterns in such systems.
Take your functional programming skills to the next level by joining me in developing a distributed system powered by Apache Pulsar and Fs2 streams, all in Scala 3!
R Programming for Data Science
Roger D. PengThis book brings the fundamentals of R programming to you, using the same material developed as part of the industry-leading Johns Hopkins Data Science Specialization. The skills taught in this book will lay the foundation for you to begin your journey learning data science. Printed copies of this book are available through Lulu.
Concurrency with Modern C++
Rainer GrimmC++11 is the first C++ standard that deals with concurrency. The story goes on with C++17, C++20, and will continue with C++23.
I'll give you a detailed insight into the current and the upcoming concurrency in C++. This insight includes the theory and a lot of practice.
Thinking with Types
Sandy MaguireThis book aims to be the comprehensive manual for type-level programming. It's about getting you from here to there---from a competent Haskell programmer to one who convinces the compiler to do their work for them.
Biological Modeling
Phillip CompeauIn this ebook, learn why zebras have stripes, why SARS-CoV-2 spread so quickly around the planet, how to train a computer to classify cellular images, and more!
Top Bundles
- #1
CCIE Service Provider Ultimate Study Bundle
2 Books
Piotr Jablonski, Lukasz Bromirski, and Nick Russo have joined forces to deliver the only CCIE Service Provider training resource you'll ever need. This bundle contains a detailed and challenging collection of workbook labs, plus an extensively detailed technical reference guide. All of us have earned the CCIE Service Provider certification... - #2
Modern C++ Collection
3 Books
Get All about Modern C++C++ Standard Library, including C++20Concurrency with Modern C++, including C++20C++20Each book has about 200 complete code examples. Updates are included. When I update one of the books, you immediately get the updated bundle. You can expect significant updates to each new C++ standard (C++23, C++26, .. ) and also... - #3
Software Architecture
2 Books
"Software Architecture for Developers" is a practical and pragmatic guide to modern, lightweight software architecture, specifically aimed at developers. You'll learn:The essence of software architecture.Why the software architecture role should include coding, coaching and collaboration.The things that you really need to think about before... - #4
Practical FP in Scala + Functional event-driven architecture
2 Books
Practical FP in Scala (A hands-on approach) & Functional event-driven architecture, aka FEDA, (Powered by Scala 3), together as a bundle! The content of PFP in Scala is a requirement to understand FEDA so why not take advantage of this bundle!? - #6
Pattern-Oriented Memory Forensics and Malware Detection
2 Books
This training bundle for security engineers and researchers, malware and memory forensics analysts includes two accelerated training courses for Windows memory dump analysis using WinDbg. It is also useful for technical support and escalation engineers who analyze memory dumps from complex software environments and need to check for possible... - #8
Learn Git, Bash, and Terraform the Hard Way
3 Books
Learn Git, Bash and Terraform using the Hard Way method.These technologies are essential tools in the DevOps armoury. These books walk you through their features and subtleties in a simple, gradual way that reinforces learning rather than baffling you with theory. - #9
Quality Software
11 Books
The Quality Software Bundle is for managers, would-be managers, and any of us who find themselves being managed and confused. This comprehensive bundle covers the entire span of software development approaches, from hacking through waterfall, cascade, prototyping, Iterative enhancement, reusable code, off-the-shelf, to Agile teams. The bundle... - #10
Static Analysis and Automated Refactoring
2 Books
As PHP developers we are living in the "Age of Static Analysis". We can use a tool like PHPStan to learn about potential bugs before we ship our code to production, and we can enforce our team's programming standards using custom PHPStan rules. Recipes for Decoupling by Matthias Noback teaches you in great detail how to do this, while also...