<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Alexander Garzon &#187; mysql</title>
	<atom:link href="http://agarzon.php.com.ve/tag/mysql/feed/" rel="self" type="application/rss+xml" />
	<link>http://agarzon.php.com.ve</link>
	<description>... porque no todo es PHP.</description>
	<lastBuildDate>Sun, 05 Feb 2012 15:57:47 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Optimizar todas las tablas MySQL con mysqlcheck</title>
		<link>http://agarzon.php.com.ve/optimizar-todas-las-tablas-mysql-con-mysqlcheck/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=optimizar-todas-las-tablas-mysql-con-mysqlcheck</link>
		<comments>http://agarzon.php.com.ve/optimizar-todas-las-tablas-mysql-con-mysqlcheck/#comments</comments>
		<pubDate>Wed, 09 Nov 2011 01:17:21 +0000</pubDate>
		<dc:creator>Alexander Garzon</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[mysql]]></category>

		<guid isPermaLink="false">http://agarzon.php.com.ve/?p=470</guid>
		<description><![CDATA[Optimizar todas las tablas de todas las bases de datos MySQL con mysqlcheck -Ao --auto-repair -p -u admin]]></description>
			<content:encoded><![CDATA[<p>Optimizar todas las tablas de todas las bases de datos MySQL con</p>
<pre class="brush: shell; ">

mysqlcheck -Ao --auto-repair -p -u admin
</pre>
]]></content:encoded>
			<wfw:commentRss>http://agarzon.php.com.ve/optimizar-todas-las-tablas-mysql-con-mysqlcheck/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Entendiendo los JOINS con gráficos</title>
		<link>http://agarzon.php.com.ve/entendiendo-los-joins-con-graficos/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=entendiendo-los-joins-con-graficos</link>
		<comments>http://agarzon.php.com.ve/entendiendo-los-joins-con-graficos/#comments</comments>
		<pubDate>Sun, 09 Jan 2011 20:57:09 +0000</pubDate>
		<dc:creator>Alexander Garzon</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[mysql]]></category>

		<guid isPermaLink="false">http://agarzon.php.com.ve/?p=372</guid>
		<description><![CDATA[No es de sorprender que son muchos los programadores o administradores de bases de datos quienes recién se inician, que el comprender las consultas relacionales entre distintas tablas puede resultar algo difícil de comprender, de visualizar. Sabiendo que las imágenes se fijan mejor en nuestro cerebro que sólo leer, traigo a ustedes una adaptación del [...]]]></description>
			<content:encoded><![CDATA[<p>No es de sorprender que son muchos los programadores o administradores de bases de datos quienes recién se inician, que el comprender las consultas relacionales entre distintas tablas puede resultar algo difícil de comprender, de visualizar.</p>
<p>Sabiendo que las imágenes se fijan mejor en nuestro cerebro que sólo leer, traigo a ustedes una adaptación del articulo escrito por mi colega <a href="http://www.linkedin.com/in/ligaya">Ligaya Turmelle</a> en el año 2007 pero que cuya vigencia es válida aun hoy.</p>
<p>A continuación observemos estos diagramas de Venn y conozcamos los tipos de relaciones JOIN entre tablas de una base de datos.</p>
<p><strong>La base: un diagrama vacío</strong></p>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/basicvenn.png" alt="" title="basicvenn" width="300" height="188" class="aligncenter size-full wp-image-373" /></p>
<p>El círculo T1 representa a todos los registros de la tabla 1 y el círculo T2 representa todos los registros de la tabla 2. Note como se sobrepone un poco en el medio, donde ambos círculos coinciden.</p>
<p><strong>INNER JOIN</strong><br />
Un inner join sólo retorna los registros donde &#8220;conciden&#8221; entre las dos tablas. Así que por cada registro devuelto de T1 habrá uno enlazado por el foreign key con T2. En programación esto equivale al operador lógico AND.</p>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/venn1.png" alt="" title="venn1" width="300" height="188" class="aligncenter size-full wp-image-376" /></p>
<p><strong>OUTER JOIN</strong><br />
Un outer join es lo opuesto al inner join. Sólo retorna los registros que no están en T1 y T2, es decir: donde no coinciden. En programación esto equivale al NOT AND.</p>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/outervenn.png" alt="" title="outervenn" width="300" height="188" class="aligncenter size-full wp-image-378" /></p>
<p><strong>LEFT JOIN</strong><br />
LEFT JOIN devolverá todos los registros de la tabla izquierda (T1), sin importar si coincide o no con la tabla derecha (T2). Si llega a suceder una coincidencia con los registros en la tabla T2, pues los devolverá también. Si no, los rellenará con NULL.</p>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/left_venn.png" alt="" title="left_venn" width="300" height="188" class="aligncenter size-full wp-image-379" /></p>
<p>Como podrán apreciar se puede realizar exactamente lo mismo con la tabla derecha T2, y se conoce como RIGHT JOIN, sin embargo en la mayoría de los casos sólo se usa el LEFT JOIN.</p>
<p><strong>LEFT OUTER JOIN</strong><br />
Un left outer join combina los conceptos del left join y del outer join. Básicamente se obtendrán todos los registros de la tabla izquierda (T1) menos donde coincida con la tabla derecha (T2).</p>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/leftOutervenn.png" alt="" title="leftOutervenn" width="300" height="188" class="aligncenter size-full wp-image-380" /></p>
<p>Nuevamente observe que lo mismo puede ser aplicado con la tabla derecha (T2), conocido entonces como RIGHT OUTER JOIN. Aunque la mayoría prefiera referirse a la tabla izquierda siempre.</p>
<p><strong>THETA JOIN</strong><br />
Es el producto cartesiano entre las dos tablas, y seguramente no es lo que se desea, ya que puede provenir del resultado de una mala consulta y entonces obtener más registros de los que realmente esperaba.</p>
<pre class="brush: sql; ">
SELECT t1.*, t2.*
FROM table1 t1, table2 t2
WHERE t1.id = 5;
</pre>
<p style="text-align: center;"><img src="http://agarzon.php.com.ve/wp-content/uploads/2011/01/thetavenn.png" alt="" title="thetavenn" width="300" height="188" class="aligncenter size-full wp-image-382" /></p>
<p>Y allí lo tienen, quizá en el futuro cuando necesiten realizar relaciones entre tablas y necesiten una pista, espero este artículo les sea de ayuda.</p>
]]></content:encoded>
			<wfw:commentRss>http://agarzon.php.com.ve/entendiendo-los-joins-con-graficos/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>10 errores comunes cuando se trabaja con MySQL</title>
		<link>http://agarzon.php.com.ve/10-errores-comunes-cuando-se-trabaja-con-mysql/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=10-errores-comunes-cuando-se-trabaja-con-mysql</link>
		<comments>http://agarzon.php.com.ve/10-errores-comunes-cuando-se-trabaja-con-mysql/#comments</comments>
		<pubDate>Fri, 19 Nov 2010 16:10:30 +0000</pubDate>
		<dc:creator>Alexander Garzon</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://agarzon.php.com.ve/?p=326</guid>
		<description><![CDATA[Lo primero, decir que está es una traducción y adaptación libre del artículo cuyo autor es Craig Buckler. Aclarado ello, conozcamos los 10 errores más comunes que cometen muchos programadores PHP cuando trabajan con MySQL. 1. Usar MyISAM en lugar de InnoDB. MySQL tiene un considerable número de motores de almacenamiento, entre los cuales lo [...]]]></description>
			<content:encoded><![CDATA[<p>Lo primero, decir que está es una traducción y adaptación libre del <a href="http://blogs.sitepoint.com/2010/11/19/mysql-mistakes-php-developers/">artículo</a> cuyo autor es Craig Buckler. Aclarado ello, conozcamos los 10 errores más comunes que cometen muchos programadores PHP cuando trabajan con MySQL.</p>
<p><strong>1. Usar MyISAM en lugar de InnoDB.</strong><br />
MySQL tiene un considerable número de motores de almacenamiento, entre los cuales lo más destacados con MyISAM e InnoDB.</p>
<p>Pero MyISAM es quien viene por defecto en toda instalación MySQL. Y muchos ignoramos esto y sencillamente lo dejamos así, pero MyISAM no soporta foreign key ni transacciones. Además, la tabla completa es bloqueada cada vez que insertamos o actualizamos un registro causando problemas de rendimiento.</p>
<p>La solución es simple: Usar InnoDB</p>
<p><strong>2. Usar las funciones mysql de PHP.</strong><br />
PHP provee un amplio set de funciones para trabajar con MySQL, y eso ha sido así desde el principio (muchos años). Funciones tales como mysql_connect, mysql_query, mysql_fetch_assoc, etc. pero ignoramos una importante mejora implementada desde PHP 5: la librería mysqli.</p>
<p>Y tal como cita el <a href="http://php.net/manual/es/mysqli.overview.php">manual oficial de PHP</a>:</p>
<blockquote><p>
Si se utiliza una versión de MySQL 4.1.3 o posterior, se recomienda encarecidamente utilizar la extensión mysqli en su lugar.
</p></blockquote>
<p>mysqli tiene notables ventajas:</p>
<ul>
<li>Una interfaz opcional orientada a objetos</li>
<li>Prepared Statements (sentencias preparadas) que ayudan a prevenir los ataques de inyección SQL e incrementa el performance.</li>
<li>Soporta la ejecución de múltiples sentencias y transacciones</li>
</ul>
<p>Además, usted podría considerar usar <a href="http://php.net/manual/es/book.pdo.php">PDO</a> si planea dar soporte a distintos tipos de bases de datos.</p>
<p><strong>3. No filtrar las entradas del usuario</strong><br />
Este es quizá el peor de todos los errores. <strong>NUNCA CONFÍE EN LO QUE LOS USUARIOS ENVÍEN</strong>. Validar todo desde el lado del servidor es algo obligatorio, no confíe en las validaciones JavaSript. Atacar un sitio por inyección SQL es tan simple como:</p>
<pre class="brush: php; ">

$username = $_POST[&quot;name&quot;];
$password = $_POST[&quot;password&quot;];
$sql = &quot;SELECT userid FROM usertable WHERE username=&#039;$username&#039; AND password=&#039;$password&#039;;&quot;;
// run query...
</pre>
<p>Esto puede ser crackeado con tan sólo ingresar  &#8220;admin&#8217;; &#8211;&#8221; en el campo de username. La cadena SQL quedaría así:</p>
<pre class="brush: sql; ">

SELECT userid FROM usertable WHERE username=&#039;admin&#039;;  
</pre>
<p>El atacante ha logrado ingresar al sistema como &#8216;admin&#8217; sin siquiera necesitar el password, porque fue comentado dentro del SQL.</p>
<p><strong>4. No usar UTF-8</strong><br />
Un gran problema respecto al manejo de los caracteres y la internacionalización (otros idiomas) es el mal uso del charset. Sin importar si lo que desarrollamos sea en inglés o español (o cualquier otro) usar UTF-8 es una gran solución. Aunque PHP no ofrezca del todo un soporte a UTF-8 (al menos hasta la versión PHP 6) MySQL si posee dicho soporte, <a href="http://dev.mysql.com/doc/refman/5.1/en/charset.html">MySQL character sets</a> </p>
<p><strong>5. Favorecer a PHP por sobre MySQL</strong><br />
MySQL posee un amplio set de funciones que puede correr como parte de la sentencia QUERY, pero muchos lo ignoramos.</p>
<p>Por ejemplo, para obtener un valor promedio de los salarios en una tabla, un programador realizaría una consulta a MySQL y traería hasta PHP todos los registros a calcular; y posteriormente realizaría el cálculo del promedio con la aritmética de PHP (y que es el lenguaje que conoce); pero la mejor opción hubiese sido aprovechar la función <a href="http://dev.mysql.com/doc/refman/5.1/en/group-by-functions.html#function_avg">AVG()</a> que trae MySQL y nos ahorramos procesos innecesarios.</p>
<p>La regla general es usar en la mayor medida posible las funciones pre-construidas en la base de datos, ahorrando procesos a PHP.</p>
<p><strong>6. No optimizar las consultas</strong><br />
El 99% de los problemas de performance en PHP se deben a sentencias y consultas SQL mal hechas. MySQL cuenta con herramientas que nos permiten medir y probar nuestras consultas a fin de buscar mejores opciones. <a href="http://dev.mysql.com/doc/refman/5.1/en/using-explain.html">Sentencia EXPLAIN</a>, <a href="http://dev.mysql.com/tech-resources/articles/using-new-query-profiler.html">Query Profiler</a> y <a href="http://www.jetprofiler.com/">algunas</a> <a href="http://myprofi.sourceforge.net/">otras</a> <a href="http://dev.mysql.com/doc/refman/5.1/en/slow-query-log.html">herramientas</a> que le ayudaran a robustecer sus SELECT.</p>
<p><strong>7. Usar tipos de campo inadecuados</strong><br />
MySQL ofrece un amplio rango de tipos numéricos, cadenas y de fechas. Si usted va a almacenar una fecha, use el campo indicado para ello DATE o DATETIME. Usar enteros o cadenas para ello, sólo le traerá problemas.</p>
<p>Es importante determinar cual es el tipo de campo ideal para cada dato que vaya a almacenar. Piénselo bien, MySQL ofrece bastante de donde escoger.</p>
<p><strong>8. Usar * en las consultas SELECT</strong><br />
Es un error terriblemente común. No use * para retornar todas las columnas de una tabla. No sea flojo ! Sea específico en definir cuales campos desea consultar, incluso si los llega a necesitar todos.</p>
<p><strong>9. No indexar o indexar más de lo necesario</strong><br />
Como regla de oro, indexe sólo donde una columna sea solicitada en una sentencia WHERE de una consulta SELECT. Saber hacerlo mejorará el performance de su base de datos y en consecuencia incrementará la velocidad de todo su sistema.</p>
<p><strong>10. Olvidar respaldar !</strong><br />
Aunque no lo crea, las cosas no siempre funcionan como esperamos. Las bases de datos se pueden corromper, el disco duro estropearse, un incendio puede consumir su datacenter e incluso su proveedor puede irse a banca rota !</p>
<p>Perder datos es algo catastrófico e imperdonable, tome todas las medidas necesarias para tener siempre a mano respaldos de sus datos, de forma automatizada y remota.</p>
<p><strong>11 La ñapa:  no considerar otras bases de datos.</strong><br />
MySQL es sin duda uno de los más famosos y extendidos entre los programadores PHP, pero no es la única opción. Existen muchas alternativas como <a href="http://www.postgresql.org/">PostgreSQL</a> y <a href="http://www.firebirdsql.org/">Firebird</a> quienes son además Software Libre y no controlados por una corporación como sí lo es MySQL. Incluso <a href="http://www.sqlite.org/">SQLite</a> puede resultar en una interesante alternativa para aplicaciones pequeñas y embebidas.</p>
]]></content:encoded>
			<wfw:commentRss>http://agarzon.php.com.ve/10-errores-comunes-cuando-se-trabaja-con-mysql/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Optimizar automáticamente todas las tablas de un servidor MySQL</title>
		<link>http://agarzon.php.com.ve/optimizar-automaticamente-todas-las-tablas-de-un-servidor-mysql/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=optimizar-automaticamente-todas-las-tablas-de-un-servidor-mysql</link>
		<comments>http://agarzon.php.com.ve/optimizar-automaticamente-todas-las-tablas-de-un-servidor-mysql/#comments</comments>
		<pubDate>Mon, 08 Feb 2010 23:14:21 +0000</pubDate>
		<dc:creator>Alexander Garzon</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[plesk]]></category>

		<guid isPermaLink="false">http://agarzon.php.com.ve/?p=193</guid>
		<description><![CDATA[En los servidores de VeneHosting.com ejecutamos semanalmente un proceso que optimiza &#8216;a juro&#8217; todas las tablas, de todas las bases de datos MySQL de todo el servidor (que vienen siendo un montón enorme!); con el fin de ayudar a mantener un buen nivel de rendimiento. Como no somos egoístas, compartimos este simple script con el [...]]]></description>
			<content:encoded><![CDATA[<p>En los servidores de <a href="http://www.venehosting.com/">VeneHosting.com</a> ejecutamos semanalmente un proceso que optimiza &#8216;a juro&#8217; todas las tablas, de todas las bases de datos MySQL de todo el servidor (que vienen siendo un montón enorme!); con el fin de ayudar a mantener un buen nivel de rendimiento.</p>
<p>Como no somos egoístas, compartimos este simple script con el resto de la comunidad y ¿porqué no?, hasta la competencia podría aprender algo más de nosotros !</p>
<pre class="brush: php; ">

&lt;?php
/* modifica estos valores según tu servidor.*/
$host=&quot;localhost&quot;;
$usuario=&quot;admin&quot;; //Tu super usuario
$pasword=&quot;xxxxx&quot;; //La clave del super-usuario

/*no modifiques nada más*/
$link=mysql_connect($host,$usuario,$pasword);

$dbs=mysql_list_dbs($link);
while ($db=mysql_fetch_object($dbs))
{
        echo &quot;$db-&gt;Database\n&quot;;
        $tablas = mysql_db_query($db-&gt;Database, &quot;SHOW TABLES&quot;, $link);
        while ($tabla=mysql_fetch_array($tablas)) {
                mysql_db_query($db-&gt;Database, &quot;OPTIMIZE TABLE &quot;.$tabla[0], $link);
                echo &quot;$tabla[0]\n&quot;;
        }
}
?&gt;
</pre>
<p>Sólo resta programar este script con CRON para que se ejecute cada X tiempo (recomendado 1 vez a la semana) y listo !</p>
]]></content:encoded>
			<wfw:commentRss>http://agarzon.php.com.ve/optimizar-automaticamente-todas-las-tablas-de-un-servidor-mysql/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Hacer un select aleatorio (random) con MySQL</title>
		<link>http://agarzon.php.com.ve/hacer-un-select-aleatorio-random-con-mysql/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=hacer-un-select-aleatorio-random-con-mysql</link>
		<comments>http://agarzon.php.com.ve/hacer-un-select-aleatorio-random-con-mysql/#comments</comments>
		<pubDate>Mon, 16 Nov 2009 18:36:03 +0000</pubDate>
		<dc:creator>Alexander Garzon</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://agarzon.php.com.ve/?p=129</guid>
		<description><![CDATA[Nota mental: ¿Queremos obtener 3 (o cualquier otra cantidad) de registros de una tabla MYSQL, pero de forma aleatoria y de paso sin que se repitan ? ORDER BY RAND() he allí el truco. &#34;SELECT * FROM producto ORDER BY RAND() LIMIT 3;&#34; Así de fácil.]]></description>
			<content:encoded><![CDATA[<p>Nota mental:</p>
<p>¿Queremos obtener 3 (o cualquier otra cantidad) de registros de una tabla MYSQL, pero de forma aleatoria y de paso sin que se repitan ?</p>
<p><strong>ORDER BY RAND()</strong> he allí el truco.</p>
<pre class="brush: sql; ">

&quot;SELECT * FROM producto ORDER BY RAND() LIMIT 3;&quot;
</pre>
<p>Así de fácil.</p>
]]></content:encoded>
			<wfw:commentRss>http://agarzon.php.com.ve/hacer-un-select-aleatorio-random-con-mysql/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>

