\documentclass[10pt,a4paper]{article} % Packages \usepackage{fancyhdr} % For header and footer \usepackage{multicol} % Allows multicols in tables \usepackage{tabularx} % Intelligent column widths \usepackage{tabulary} % Used in header and footer \usepackage{hhline} % Border under tables \usepackage{graphicx} % For images \usepackage{xcolor} % For hex colours %\usepackage[utf8x]{inputenc} % For unicode character support \usepackage[T1]{fontenc} % Without this we get weird character replacements \usepackage{colortbl} % For coloured tables \usepackage{setspace} % For line height \usepackage{lastpage} % Needed for total page number \usepackage{seqsplit} % Splits long words. %\usepackage{opensans} % Can't make this work so far. Shame. Would be lovely. \usepackage[normalem]{ulem} % For underlining links % Most of the following are not required for the majority % of cheat sheets but are needed for some symbol support. \usepackage{amsmath} % Symbols \usepackage{MnSymbol} % Symbols \usepackage{wasysym} % Symbols %\usepackage[english,german,french,spanish,italian]{babel} % Languages % Document Info \author{asourv} \pdfinfo{ /Title (sql-avanzado.pdf) /Creator (Cheatography) /Author (asourv) /Subject (SQL Avanzado Cheat Sheet) } % Lengths and widths \addtolength{\textwidth}{6cm} \addtolength{\textheight}{-1cm} \addtolength{\hoffset}{-3cm} \addtolength{\voffset}{-2cm} \setlength{\tabcolsep}{0.2cm} % Space between columns \setlength{\headsep}{-12pt} % Reduce space between header and content \setlength{\headheight}{85pt} % If less, LaTeX automatically increases it \renewcommand{\footrulewidth}{0pt} % Remove footer line \renewcommand{\headrulewidth}{0pt} % Remove header line \renewcommand{\seqinsert}{\ifmmode\allowbreak\else\-\fi} % Hyphens in seqsplit % This two commands together give roughly % the right line height in the tables \renewcommand{\arraystretch}{1.3} \onehalfspacing % Commands \newcommand{\SetRowColor}[1]{\noalign{\gdef\RowColorName{#1}}\rowcolor{\RowColorName}} % Shortcut for row colour \newcommand{\mymulticolumn}[3]{\multicolumn{#1}{>{\columncolor{\RowColorName}}#2}{#3}} % For coloured multi-cols \newcolumntype{x}[1]{>{\raggedright}p{#1}} % New column types for ragged-right paragraph columns \newcommand{\tn}{\tabularnewline} % Required as custom column type in use % Font and Colours \definecolor{HeadBackground}{HTML}{333333} \definecolor{FootBackground}{HTML}{666666} \definecolor{TextColor}{HTML}{333333} \definecolor{DarkBackground}{HTML}{A3A3A3} \definecolor{LightBackground}{HTML}{F3F3F3} \renewcommand{\familydefault}{\sfdefault} \color{TextColor} % Header and Footer \pagestyle{fancy} \fancyhead{} % Set header to blank \fancyfoot{} % Set footer to blank \fancyhead[L]{ \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{C} \SetRowColor{DarkBackground} \vspace{-7pt} {\parbox{\dimexpr\textwidth-2\fboxsep\relax}{\noindent \hspace*{-6pt}\includegraphics[width=5.8cm]{/web/www.cheatography.com/public/images/cheatography_logo.pdf}} } \end{tabulary} \columnbreak \begin{tabulary}{11cm}{L} \vspace{-2pt}\large{\bf{\textcolor{DarkBackground}{\textrm{SQL Avanzado Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{asourv} via \textcolor{DarkBackground}{\uline{cheatography.com/174053/cs/36842/}}} \end{tabulary} \end{multicols}} \fancyfoot[L]{ \footnotesize \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{LL} \SetRowColor{FootBackground} \mymulticolumn{2}{p{5.377cm}}{\bf\textcolor{white}{Cheatographer}} \\ \vspace{-2pt}asourv \\ \uline{cheatography.com/asourv} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 2nd February, 2023.\\ Updated 2nd February, 2023.\\ Page {\thepage} of \pageref{LastPage}. \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Sponsor}} \\ \SetRowColor{white} \vspace{-5pt} %\includegraphics[width=48px,height=48px]{dave.jpeg} Measure your website readability!\\ www.readability-score.com \end{tabulary} \end{multicols}} \begin{document} \raggedright \raggedcolumns % Set font size to small. Switch to any value % from this page to resize cheat sheet text: % www.emerson.emory.edu/services/latex/latex_169.html \footnotesize % Small font. \begin{multicols*}{2} \begin{tabularx}{8.4cm}{x{2.48 cm} x{5.52 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Vistas}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{Una vista es una relación o "tabla" derivada de otras relaciones, ya sean "básicas" o también derivadas} \tn % Row Count 3 (+ 3) % Row 1 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} es transparente para el usuario} \tn % Row Count 4 (+ 1) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} se genera a partir de una {\bf{consulta relacional}}} \tn % Row Count 6 (+ 2) % Row 3 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} son actualizables, pero no deben contener subselects, joins o agregaciones. Si la vista es compleja es posible que existan varias maneras de llegar a la misma conclusión.} \tn % Row Count 10 (+ 4) % Row 4 \SetRowColor{LightBackground} WHITH CHECK OPTION & Limita los UPDATES que pueden hacerse y que afectan a las vistas creadas. \tn % Row Count 13 (+ 3) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{p{0.8 cm} p{0.8 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{FUNCIONES}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} Los procedimientos almacenados son funciones definidas que se almacenan en la Base de datos. Se tratan como un objeto más de la BD} \tn % Row Count 3 (+ 3) % Row 1 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\}Simplifican el desarrollo de aplicaciones} \tn % Row Count 5 (+ 2) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\}Mejoran el rendimiento de la BD} \tn % Row Count 7 (+ 2) % Row 3 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\}Controlan las operaciones que se realizan} \tn % Row Count 9 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{p{0.8 cm} p{0.8 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{DIsparadores (TRIGGERS)}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} Proveen al DBMS con un recurso para participar de forma más activa en los procesos. Es capaz de reaccionar ante eventos.} \tn % Row Count 3 (+ 3) % Row 1 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} es muy importante la documentación de los TRIGGERS} \tn % Row Count 5 (+ 2) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\} Monitorización/ alerta ante situaciones adversas (presupuesto inferior a n)} \tn % Row Count 8 (+ 3) % Row 3 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\} Comprobación de restricciones de integridad. (no departamentos de más de n empleados)} \tn % Row Count 11 (+ 3) % Row 4 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-angle-double-right\}\} Mantenimiento automático: atributos derivados} \tn % Row Count 13 (+ 2) % Row 5 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-rocket\}\} El trigger se invoca cuando una operación altera o es susceptible de aleterar el estado correcto del sistema} \tn % Row Count 16 (+ 3) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{4 cm} x{4 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{TRANSACCIONES y CONCURRENCIA}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\{\{fa-hand-o-right\}\} Un DBMS permite el acceso simultaneo de diferentes usuarios a la misma base de datos, preservando su integridad y consistencia} \tn % Row Count 3 (+ 3) % Row 1 \SetRowColor{white} \mymulticolumn{2}{x{8.4cm}}{Una transacción es un conjunto de operaciones de lectura y/o modificación de la base de datos que deben realizarse como una sola operación, y se debe acabar confirmando (COMMIT) o cancelando (ROLLBACK).} \tn % Row Count 8 (+ 5) % Row 2 \SetRowColor{LightBackground} Toda transacción debe complir las propiedades ACID: & Atomicidad, Consistencia, Aislamiento, Definitividad \tn % Row Count 11 (+ 3) % Row 3 \SetRowColor{white} \{\{fa-check-square-o\}\} ATOMICIDAD & Las operaciones se tienen que ejecutar completamente o en absoluto. TODAS O NINGUNA \tn % Row Count 16 (+ 5) % Row 4 \SetRowColor{LightBackground} \{\{fa-check-square-o\}\} CONSISTENCIA & Las transacciones deben cumplir los requisitos de los usuarios \tn % Row Count 20 (+ 4) % Row 5 \SetRowColor{white} \{\{fa-check-square-o\}\} ISOLATION & El acceso simultáneo de dos usuarios no debe producir resultados anómalos \tn % Row Count 24 (+ 4) % Row 6 \SetRowColor{LightBackground} \{\{fa-check-square-o\}\} DEFINITIVIDAD & Han de exisitir mecanismos para evitar péridda de datos, tanto antiguos como recientes \tn % Row Count 29 (+ 5) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{3.92 cm} x{4.08 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Transacciones: INTERFERENCIAS}} \tn % Row 0 \SetRowColor{LightBackground} \{\{fa-frown-o\}\} Actualización perdida & Cuando se pierde un cambio realizado por una operación de escritura. READ UNCOMMITED, READ COMMITED, REPETEABLE READ, SERIALIZABLE \tn % Row Count 7 (+ 7) % Row 1 \SetRowColor{white} \{\{fa-frown-o\}\} Lectura no confirmada & Se lee un dato resultante de una modificación realizada por una transacción que aborta. READ COMMITED, REPETEABLE READ, SERIALIZABLE \tn % Row Count 14 (+ 7) % Row 2 \SetRowColor{LightBackground} \{\{fa-frown-o\}\} Lectura no repetible & REPETEABLE READ, SERIALIZABLE \tn % Row Count 16 (+ 2) % Row 3 \SetRowColor{white} \{\{fa-frown-o\}\} Análisis inconsistente & Interferencia respecto a la visión que varias transacciones tienen del conjunto de datos. REPETEABLE READ, SERIALIZABLE \tn % Row Count 22 (+ 6) % Row 4 \SetRowColor{LightBackground} \{\{fa-frown-o\}\} Fantasmas & Una transacción lee un conjunto de datos mientras otra añade nuevos elementos al conjunto. SERIALIZABLE \tn % Row Count 28 (+ 6) \hhline{>{\arrayrulecolor{DarkBackground}}--} \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{Estas interferencias se solucionan con las transacciones. Las transacciones sólo serán necesarias para evitar las interferencias a toda costa. No es recomendable usarlas siempre ya que puede perjudicar el rendimiento del sistema. Existen diversos niveles de posibles transacciones para equilibrar seguridad y rendimiento. \newline {\bf{SERIALIZABLE}} protege de cualquier interferencia pero imposibilita paralelizar. Esto se llama horario serial.} \tn \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{8.4cm}}{\bf\textcolor{white}{-}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{8.4cm}}{SELECT ID, nombre, sueldo, proyecto\{\{nl\}\}FROM empleados \{\{nl\}\}WHERE proyecto IN ('IoT2', 'UDT4'); \newline \{\{fa-arrow-down\}\} \newline CREATE VIEW EMPLEADOS\_IOT\_UDT AS\{\{nl\}\}(SELECT ID, nombre, sueldo, proyecto\{\{nl\}\}FROM empleados\{\{nl\}\}WHERE proyecto IN ('IoT2', 'UDT4'));} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{8.4cm}}{\bf\textcolor{white}{-}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{8.4cm}}{CREATE FUNCTION encontrar\_peliculas RETURN TABLE (tconst char(10)) \newline AS \$contenga\_pal\$ \newline BEGIN \newline RETURN QUERY \newline SELECT t.tconst \newline FROM title\_basics t \newline WHERE t.primarytitle LIKE CONCAT ('\%', palabra, '\%'); \newline END; \$contenga\_pal\$ \newline LANGUAGE plpgsql; \newline \newline SELECT * FROM encontrar\_peliculas ('AVATAR');} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{4 cm} x{4 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Ejemplos TRIGGERS}} \tn % Row 0 \SetRowColor{LightBackground} BEFORE \& FOR EACH STATEMENT: & Se ejecuta una sola vez, antes de la ejecución de la sentencia que dispara el trigger \tn % Row Count 5 (+ 5) % Row 1 \SetRowColor{white} BEFORE \& FOR EACH ROW & se ejecuta una sola vez por cada tupla afectada, y justo antes de que la fila se inserte, modifique o borre \tn % Row Count 11 (+ 6) % Row 2 \SetRowColor{LightBackground} AFTER \& FOR EACH ROW & Se ejecuta una sola vez por cada fila afectada, y justo después de la ejecución de la sentencia que dispara el trigger \tn % Row Count 17 (+ 6) % Row 3 \SetRowColor{white} AFTER \& FOR EACH STATEMENT & se ejecuta una sola vez después de la ejecución de la sentencia que dispara el trigger \tn % Row Count 22 (+ 5) % Row 4 \SetRowColor{LightBackground} Variables accesibles dentro de la función que ejecuta el trigger: & TG\_OP: contiene qué provocó el salto del disparador: INSTERT, DELETE o UPDATE \tn % Row Count 26 (+ 4) % Row 5 \SetRowColor{white} & NEW: Valores de la tupla después del UPDATE o INSERT. No se define para DELETE. \tn % Row Count 30 (+ 4) \end{tabularx} \par\addvspace{1.3em} \vfill \columnbreak \begin{tabularx}{8.4cm}{x{4 cm} x{4 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Ejemplos TRIGGERS (cont)}} \tn % Row 6 \SetRowColor{LightBackground} & OLD: valores de la tupla antes de la ejecución del UPDATE o DELETE. No se define para INSERT. \tn % Row Count 5 (+ 5) \hhline{>{\arrayrulecolor{DarkBackground}}--} \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{CREATE TRIGGER nombre\_trigger \newline \{BEFORE || AFTER\} \newline \{INSERT || DELETE || UPDATE\} \newline ON \newline nombre\_relacion \newline FOR EACH \{ROW || STATEMENT\} \newline EXECUTE PROCEDURE \seqsplit{nombreFunción(argumentos);} \newline \newline CREATE FUNCTION nombreFunción() \newline RETURNS trigger AS \$\$ \newline BEGIN \newline {[}...{]} \newline RETURN \{NULL || NEW || OLD\}; \newline END; \newline \$\$ LANGUAGE plpgsql;} \tn \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{8.4cm}}{\bf\textcolor{white}{-}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{8.4cm}}{UPDATE productos \newline SET stock = stock + 10 \newline WHERE ID = '1123S' \newline \newline OLD.ID='1123S' \newline OLD.stock = \#stock \newline NEW.ID='1123S' \newline NEW.stock=\#stock+10} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{8.4cm}}{\bf\textcolor{white}{-}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{8.4cm}}{BEGIN TRANSACTION ISOLATION LEVEL SERIALIZABLE; \newline CREATE TABLE tabla\_nueva (ID INTEGER PRIMARY KEY); \newline COMMIT;} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} % That's all folks \end{multicols*} \end{document}