MySQL | Denominações CASE SENSITIVE

A variável lower_case_table_names condiciona a forma como o servidor de MySQL armazena e gera os nomes dos objectos da base de dados, comparando os nomes entre si e com os comandos produzidos pelos utilizadores.

Por defeito, e.g., em Windows e de modo a assegurar uma melhor interoperabilidade entre bases de dados instaladas em diferentes computadores e sistemas operativos, o valor dessa variável é “1”, o que significa que todos os nomes são guardados em letra minúscula.
Para optimizar a gestão, utilização e desenho de interfaces é aconselhável que as denominações dos objectos, por exemplo tabelas e colunas, de uma base de dados sejam definidos como case sensitive. Desse modo quando se geram, e.g., mapas impressos ou ecrãs deixa de ser necessária a tarefa repetitiva de alterar as letras iniciais das denominações para letra maiúscula. Por exemplo: “número de aluno” para “Número de Aluno”. Pode parecer um pormenor mas em centenas de ecrãs serão largas dezenas de horas de programação que serão poupadas.
Ao optar pelo valor “0” os nomes são guardados e comparados na forma como foram escritos; caso a variável assuma o valor “1” as denominações são armazenadas em letra minúscula e as comparações não dependem das letras serem maiúsculas ou minúsculas; se o valor for “2” os nomes são guardados como foram escritos, mas são sempre comparados em letra minúscula.
Como se altera este parâmetro?
O método mais simples e expedito é utilizar o ficheiro de configuração “my.ini” que o servidor lê cada vez que é inicializado. Basta alterar a variável lower_case_table_names para o valor pretendido (caso a variável não esteja presente então deve ser adicionada ao fim do referido ficheiro). Finalmente, é ainda necessário re-inicializar o servidor de MySQL. Em Windows, e numa instalação padrão, esse ficheiro está localizado em “C:ProgramDataMySQLMySQL Server Xmy.ini”; em que X deve ser substituído, caso a caso, pelo número da versão de MySQL.
__________________________________________________
Nota: Em MacOS a variável tem o valor pré-definido de “2”, e em Unix é de “Ø”.

MySQL | Algumas características

O MySQL é o sistema de gestão de bases de dados open source mais utilizado em todo o mundo. Quando comparado com outros sistemas de uso livre como, por exemplo, o PostgreSQL, o MySQL tem muitas vantagens das quais se referem algumas em seguida:
  • Apesar de ser um SGBDR (Sistema de Gestão de Base de Dados Relacional) com altos níveis de performance é todavia de fácil utilização, quer nas tarefas de exploração da informação quer em termos de administração da base de dados;
  • Utiliza a linguagem padrão SQL (Structured Query Language) comum a todos os sistemas comercias mais utilizados: Oracle, SQL Server, DB2;
  • É um sistema multithreaded (múltiplas tarefas num único processo) pelo que aceita a ligação de múltiplos clientes e, por sua vez, cada cliente pode utilizar várias bases de dados em simultâneo. Um servidor de MySQL pode funcionar em múltiplos sistemas operativos incluindo os mais conhecidos (Windows, Linux, Unix e Mac OS), e aceita ligações de sistemas operativos externos pois suporta os protocolos ODBC, JDBC e .NET. A utilização destes protocolos permite que os mais diversos tipos de clientes tenham acesso às bases de dados em MySQL. Assim, é possível aceder a uma base de dados através de uma folha de cálculo, ou de outro tipo de aplicação, de uma forma transparente para o utilizador;
  • O MySQL incorpora altos níveis de conectividade podendo ser acedido a partir de qualquer nó da Internet. Por outro lado, este SGBDR possui apertados controlos de acesso à informação: para além das credenciais de acesso associadas a cada utilizador, tem ainda regras de acesso aos dados que possibilitam que, por exemplo, um determinado conjunto de dados possa ser visualizado por dois utilizadores mas que só um deles os possa modificar. Já em termos de segurança da conexão utiliza ligações encriptadas através do protocolo SSL (Secure Sockets Layer);
  • Este SGBDR é um project Open Source (apesar de ser agora propriedade da Oracle Corporation) que disponibiliza este software em duas vertentes principais: através de uma licença GNU de domínio público, ou por intermédio de licenças comerciais em que as organizações passam a dispor de suporte técnico especializado. A plena disponibilidade das distribuições de uso livre significa que basta ter acesso à Internet para que qualquer interessado as consiga obter.

MySQL | Dicionário de dados

Uma instalação de MySQL tem por defeito três bases de dados (de sistema): information_schema, mysql e performance_schema. O repositório mysql contém o dicionário de dados do sistema MySQL. Uma cópia, apenas com a função de leitura, é guardada na base de dados information_schema. O dicionário de dados é totalmente constituído por tabelas.
Nunca, em nenhum caso – nem com nenhuma justificação -, se deve alterar directamente as tabelas do dicionário de dados pois isso leva SEMPRE a consequências muito nefastas quer na disponibilidade e/ou quer no mero funcionamento do sistema de base de dados.

MySQL | Utilizador | Login

A segurança do MySQL avalia os utilizadores consoante as suas coordenadas de origem. A chave de segurança é composta por três parâmetros: nome do utilizador (user name), palavra-chave (password) e computador (host). Na gestão de utilizadores convém ter muita atenção com os valores para host pois frequentemente a entrada de um utilizador é recusada apenas por ter a máquina de origem mal atribuída.

O parâmetro host pode ter três valores:

  • localhost. O utilizador apenas pode ligar-se a partir da mesma máquina onde funciona o servidor de MySQL.
  • IP/domínio. A ligação somente será efectuada a partir de um determinado IP ou de um domínio.
  • %. A ligação pode ser feita a partir de qualquer máquina e/ou domínio. Funciona como um “trunfo”, i.e., representa qualquer computador, quer esteja na rede local ou na Internet.

MySQL | Listener

O listener (“aquele que ouve”) é um serviço lançado quando o daemon(1) do MySQL é iniciado. O listener é um subprocesso dependente do próprio servidor da base de dados, e corre ma porta que estiver especificada no ficheiro de configuração mysql.ini. Por defeito, quer seja em Windows ou Linux, por exemplo, está assignado à porta 3306.
Num sistema Windows pode verificar-se se o processo está a correr acedendo ao gestor GUI de serviços, ou utilizando a janela de comandos com a seguinte instrução:

netstat -a | findstr /C:LISTENING | findstr /C:3306

1 Programa de computador que corre em backgound, i.e., sem controlo directo pelo utilizador.

MySQL | Motores de base de dados

São os motores (engines) de base de dados que orientam os processos que asseguram a integridade dos dados, o modo como a estrutura física dos dados se organiza e, ainda, os mecanismos que asseguram a associação entre as estruturas lógicas e físicas do sistema.
No MySQL 5.6 existem os seguintes tipos principais de motores:
  • InnoDB. Motor que implementa o mecanismo ACID.
  • MyISAM. Anteriormente à versão 5.6 era o motor por defeito do MySQL; motor não-transaccional.
  • Memory. Um motor que funciona unicamente na memória (física ou virtual).
  • Archive. Destina-se ao arquivamento de dados raramente utilizados.
Para ver todos os motores disponíveis pode digitar-se, numa janela de Command Line do MySQL, a seguinte instrução: “SHOW ENGINES;”.

MySQL | Motor InnoDB

O motor InnoDB mantém um conjunto de logs em tudo semelhante ao que faz o Oracle. Esses logs (ou registos) destinam-se a assegurar a integridade das transacções ao mesmo tempo qye optimizam o custo transaccional. Este tipo de motor faz com o MySQL seja uma base de dados tipicamente transaccional. O InnoDB implementa as transacções ACID, o lock a nível da linha, além de assegurar a integridade referencial.

MySQL 5.6 | Arquitectura | Parte I

O superutilizador/DBA principal em MySQL denomina-se root (em Oracle é o utilizador SYS). Em MySQL uma base de dados é gerida de uma forma lógica e é o SGBDR que trata do armazenamento físico. O trabalho em SQL é controlado pela componente “MySQL Monitor” (em Oracle quem trata disso é o PL/SQL). A partir da versão 5.6 o MySQL já inclui a capacidade de processar XML.
Em MySQL é possível trabalhar com vários motores de base de dados, mas o único que assegura as propriedades transaccionais ACID é o InnoDB. Para além desse aspecto o motor InnoDB é o único que garante a regra de integridade referencial, e do protocolo X/Open XA para o processamento distribuído de transacções. O InnoDB é o motor por defeito em MySQL.