miércoles, 23 de octubre de 2013

Tips al diseñar tablas

Al momento de #diseñar las tablas es importante tomar en cuenta los siguientes tips.

  • Nombres de tablas y campos en menos de 64 caracteres, a su vez recordemos que al crear un indice, se tiene que dar un nombre al indice, que tambien NO puede ser de mas de 64 caracteres.
  • Utilizar el guión bajo (_) para separar palabras. Aunque deben tomar en cuenta que en consultas, muy probablemente se tenga que escapar este simbolo, es decir,
no es lo mismo
show tables like 'res_%' 
que
show tables like 'res\_%';
  • Utilizar palabras en minúsculas, sobre todo si trabajas en linuxs.
  • Los nombres de las tablas deberían ir en plural y los nombres de los campos en singular
  • Utilizar el prefijo "id" en las columnas de clave primaria y foránea.
Si tenemos la tabla empresa y el campo id, como su identificador, y vamos a la tabla venta, el campo que haga referencia ala empresa debiera quedar como empresa_id
  • En una tabla, colocar primero la clave primaria seguida de las claves foráneas, despues sus atributos.
  • Los nombres de los campos deben ser descriptivos de su contenido.

Todo esto para tener una estructura mas entendible y ahorrar dolores de cabesa. Y si esto lo hicieramos en un comienzo del diseño super excelente, ya que luego llega lo correctivo y es mas engorroso.

Saludos.

miércoles, 16 de octubre de 2013

Respaldar procedimientos MySQL.

#Respaldar procedimientos MySQL.

Si lo que ocupan es unicamente respaldar los procedimientos almancenados de alguna base de datos, les dejo el siguiente query:


mysqldump --routines --no-create-info --no-data --no-create-db --skip-opt nombre_basededatos > dump_procedures.sql


Deberan tener cuidado con el usuario que generan dicho respaldo, dado que si no tiene los suficientes derechos el usuario, solo respaldara los que le sean permitidos.

Seguimos en contacto.

martes, 15 de octubre de 2013

Modificar muchas tablas.

Generar un script que nos ayude a modificar muchas tablas.

Si requieren ejecutar alguna modificacion en las tablas de cierta base de datos como por ejemplo el cambio del collate, lo pueden realizar con una consulta algo asi:

SELECT CONCAT('ALTER TABLE `', t.`TABLE_SCHEMA`, '`.`', t.`TABLE_NAME`,
'` CONVERT TO CHARACTER SET utf8 COLLATE utf8_unicode;') as FRST
FROM `information_schema`.`TABLES` t WHERE t.`TABLE_SCHEMA` = 'nombre_basedatos';

Esta les regresara la salida de los alter de todas las tablas, se copia a la consola de ejecución y listo.

Con un poco de imaginación, detalles como estos se pueden generar para realizar muchas mas operaciones.

Saludos a todos.

viernes, 11 de octubre de 2013

Variables del Sistema MySQL

Les recomiendo ENORMEMENTE revisar este tema y analizarlo, es increiblemente lo que puede ayudar a nuestro servicio al realizar una correcta configuración de estas variables.

Les recomiendo ponerle atención a algunas como:

datadir =  Donde se localizan los archivos de las base de datos (y tablas)
tmpdir = Donde se localiza el directorio para tablas temporales
tmp_table_size = El tamaño de las tablas tempoarles permitido antes de que use disco físico.
max_heap_table_size = Máximo tamaño permitido para las tablas de memoria (Memory)
query_cache_limit = El limite de cache utilizado para las consultas
query_cache_size = El tamaño del cache utilizado por consulta
query_cache_type = La forma en que se usara el cache, 0 = no usa el cache, 1 = para todo lo que no traiga SELECT y 2 para puros SELECT.
max_user_connections = Máximo de usuarios simultaneos que se pueden conectar.
interactive_timeout =  El tiempo que espera el servidor para actividad interactiva, antes de cerrar una conexion.
wait_timeout = El tiempo que espera el servidor para recibir una conexion, antes de cerrarla.
connect_timeout = Numero de segundos antes de que el servidor responda con el mensaje de error.
thread_cache_size = Es la cantidad threads (hilos), que pueden estar en cache.
key_buffer = Los bloques de indices se guardan en buffer y se comparten con los threads.
join_buffer = El tamaño de buffer que se usa para joins que no usan indices.
max_connect_errors = Numero de conexiones interrumpidas de un equipo, ese equipo se bloqueara.
max_allowed_packet = Tamaño máximo de los paquete so cadenas generados, si se usan campos BLOB grandes se debe incrementar, lo optimo que este del tamaño del BLOB mas grande.
table_cache = Numero de las tablas abiertas simultaneamente por los thread dados.
sort_buffer_size = Acerlera las operaciones que contengan order by y group by, ya que reserva buffer segun su tamaño.
read_buffer_size = Cada que se hace un escaneo de registros se guardan en buffer, esta variable permite una mayor velocidad entre mas grande sea el numero.
read_rnd_buffer_size = Al leer los registros ordenados (tras una ordenación), los registros se leen de su buffer para evitar volver a buscar en disco, al agregarle mayor valor a esta variable, mejora mucho el rendimiento,pero es por cliente, por lo tanto s tiene que tener cuidado.
thread_concurrency = Cantidad de thread que se pueden ejecutar simultaneos desde una aplicación dada.
myisam_sort_buffer_size = Bufer resarvado para la ordenación de indices MyISAM
log-slow-queries = Archivo donde se guardan esas consultas consideradas por nosotros como lentas.
long_query_time = Numero de segundos en que tarda un query, si pasa de este tiempo, lo mete al log de queries lentos.
open_files_limit = Numero de archivos que se pueden abrir simultaneamente, cabe mencionar que el leer una tabla es como abrir archivos.
max_allowed_packet = Maximo del tamaño del paquete que viaja por la red autorizado.
no-auto-rehash = Configuración que nos ayuda a que al abrir por consola el MySQL sea mas rapido, no levanta todas las configuraciones.

Para ondar mas en el tema pues aquí