Você está na página 1de 67

Apostila de PHP com MySQL

1












PHP com MySQL










Enviada por:
Jos Henrique Monteiro De Almeida

Apostila de PHP com MySQL

2
Sumrio

1. INTRODUO AO PHP............................................................................................................................................. 4
1.1. O QUE PHP?........................................................................................................................................................... 4
1.2. COMO SURGIU A LINGUAGEM PHP?.......................................................................................................................... 4
1.3. CARACTERSTICAS DA LINGUAGEM PHP.................................................................................................................. 5
1.4. CONFIGURAO DO IIS............................................................................................................................................. 5
1.5. TESTANDO O PHP..................................................................................................................................................... 5
2. SINTAXE DO PHP....................................................................................................................................................... 6
2.1. DELIMITANDO O CDIGO PHP .................................................................................................................................. 6
2.2. SEPARADOR DE INSTRUES..................................................................................................................................... 6
2.3. COMENTRIOS.......................................................................................................................................................... 6
2.4. IMPRIMINDO CDIGO HTML....................................................................................................................................... 7
3 VARIVEIS................................................................................................................................................................ 8
3.1. NOMES DE VARIVEIS............................................................................................................................................... 8
3.2. TIPOS SUPORTADOS.................................................................................................................................................. 8
3.3. TRANSFORMAO DE TIPOS.................................................................................................................................... 11
4. OPERADORES........................................................................................................................................................... 14
4.1. OPERADORES ARITMTICOS ................................................................................................................................... 14
4.2. OPERADORES DE STRINGS ...................................................................................................................................... 14
4.3. OPERADORES DE ATRIBUIO................................................................................................................................. 14
4.4. OPERADORES BIT A BIT........................................................................................................................................... 15
4.5. OPERADORES LGICOS........................................................................................................................................... 15
4.6. OPERADORES DE COMPARAO ............................................................................................................................. 15
4.7. OPERADORES DE EXPRESSO CONDICIONAL........................................................................................................... 15
4.8. OPERADORES DE INCREMENTO E DECREMENTO...................................................................................................... 15
5. ESTRUTURAS DE CONTROLE............................................................................................................................. 17
5.1. BLOCOS .................................................................................................................................................................. 17
5.2. ESTRUTURA IF / ELSE / ELSEIF ................................................................................................................................. 17
5.3. ESTRUTURA SWITCH CASE ..................................................................................................................................... 20
5.4. ESTRUTURAS DE REPETIO................................................................................................................................... 22
5.4.1. WHILE ................................................................................................................................................................. 22
5.4.2. DO ... WHILE........................................................................................................................................................ 23
5.4.3. FOR...................................................................................................................................................................... 23
5.5. QUEBRA DE FLUXO ................................................................................................................................................. 24
5.5.1. BREAK................................................................................................................................................................. 24
5.5.2. CONTINUE............................................................................................................................................................ 24
6. FUNES................................................................................................................................................................... 26
6.1. ESCOPO DE VARIVEIS..................................................................................................................................... 28
6.2. GLOBAIS................................................................................................................................................................. 28
6.3. LOCAIS ................................................................................................................................................................... 29
6.4. ESTTICAS.............................................................................................................................................................. 29
6.5. CONSTANTES .......................................................................................................................................................... 30
7. UTILIZANDO FORMULRIOS HTML................................................................................................................ 31
7.1. DEFININDO UM FORMULRIO.................................................................................................................................. 31
7.2. INTERAGINDO O PHP COM OS FORMULRIOS HTML............................................................................................. 35
7.3. VARIVEL $_POST................................................................................................................................................ 35

Apostila de PHP com MySQL

3
8. TRABALHANDO COM MYSQL............................................................................................................................. 40
8.1. O BANCO DE DADOS MYSQL................................................................................................................................. 40
8.2. CARACTERSTICAS DO MYSQL .............................................................................................................................. 41
8.3. O QUE O MYSQL FAZ DE MELHOR.......................................................................................................................... 41
8.3. O MYSQL GRATUITO ? ........................................................................................................................................ 41
8.4. TIPOS DE DADOS DO MYSQL.................................................................................................................................. 42
8.5. COMANDOS BSICOS DO SQL ................................................................................................................................ 45
8.6. MANIPULANDO DADOS DAS TABELAS ..................................................................................................................... 46
9. CONEXO COM O MYSQL VIA PHP .................................................................................................................. 49
9.1. ABRINDO E FECHANDO CONEXO COM O MYSQL................................................................................................. 49
9.2. TRATAMENTO DE RESULTADOS DE QUERY SELECT................................................................................................. 52
10. UTILIZANDO HEADERS ...................................................................................................................................... 55
11. UTILIZANDO COOKIES....................................................................................................................................... 56
11.1. O QUE SO COOKIES............................................................................................................................................. 56
11.2. GRAVANDO COOKIES ............................................................................................................................................ 56
11.3. LENDO COOKIES GRAVADOS ................................................................................................................................. 57
13. TRABALHANDO COM SESSES (SESSIONS) ................................................................................................ 59
13.1. FUNO SESSION_REGISTER() .............................................................................................................................. 59
14. FUNES DO PHP ................................................................................................................................................. 60
14.1. FUNES DIVERSAS .............................................................................................................................................. 60
14.2. FUNES DE MANIPULAO DE ARQUIVOS........................................................................................................... 66

Apostila de PHP com MySQL

4
1. Introduo ao PHP


1.1. O que PHP?

O PHP uma linguagem que permite criar sites WEB dinmicos, possibilitando uma interao com o
usurio atravs de formulrios, parmetros da URL e links. A diferena de PHP com relao a linguagens
semelhantes a Javascript que o cdigo PHP executado no servidor, sendo enviado para o cliente
apenas html puro.

Desta maneira possvel interagir com bancos de dados e aplicaes existentes no servidor, com a
vantagem de no expor o cdigo fonte para o cliente. Isso pode ser til quando o programa est lidando
com senhas ou qualquer tipo de informao confidencial.

O que diferencia PHP de um script CGI escrito em C ou Perl que o cdigo PHP fica embutido no prprio
HTML, enquanto no outro caso necessrio que o script CGI gere todo o cdigo HTML, ou leia de um outro
arquivo.


1.2. Como surgiu a linguagem PHP?

A linguagem PHP foi concebida durante o outono de 1994 por Rasmus Lerdorf. As primeiras verses no
foram disponibilizadas, tendo sido utilizadas em sua home-page apenas para que ele pudesse ter
informaes sobre as visitas que estavam sendo feitas.

A primeira verso utilizada por outras pessoas foi disponibilizada em 1995, e ficou conhecida como
Personal Home Page Tools (ferramentas para pgina pessoal). Era composta por um sistema bastante
simples que interpretava algumas macros e alguns utilitrios que rodavam por trs das home-pages: um
livro de visitas, um contador e algumas outras coisas.

Em meados de 1995 o interpretador foi reescrito, e ganhou o nome de PHP/FI, o FI veio de um outro
pacote escrito por Rasmus que interpretava dados de formulrios HTML (Form Interpreter).

Ele combinou os scripts do pacote Personal Home Page Tools com o FI e adicionou suporte a mSQL,
nascendo assim o PHP/FI, que cresceu bastante, e as pessoas passaram a contribuir com o projeto.

Estima-se que em 1996, PHP/FI estava sendo usado por cerca de 15.000 sites pelo mundo, e em meados
de 1997 esse nmero subiu para mais de 50.000. Nessa poca houve uma mudana no desenvolvimento
do PHP.

Ele deixou de ser um projeto de Rasmus com contribuies de outras pessoas para ter uma equipe de
desenvolvimento mais organizada. O interpretador foi reescrito por Zeev Suraski e Andi Gutmans. Esse
novo interpretador foi base para a verso 3.

O lanamento do PHP4, ocorrido em 22/05/2000, trouxe muitas novidades aos programadores de PHP.
Uma das principais foi o suporte a sesses, bastante til pra identificar o cliente que solicitou determinada
informao.

Alm das mudanas referentes a sintaxe e novos recursos de programao, o PHP4 trouxe como novidade
um otimizador chamado Zend, que permite a execuo muito mais rpida de scripts PHP.A empresa que
produz o Zend promete para este ano o lanamento de um compilador de PHP. Cdigos compilados sero
executados mais rapidamente, alm de proteger o fonte da aplicao. Hoje, j se encontra disponvel no
mercado a verso 5.x do PHP.


Apostila de PHP com MySQL

5
1.3. Caractersticas da Linguagem PHP

uma linguagem de fcil aprendizado;

Tem suporte a um grande nmero de bancos de dados como: dBase, Interbase, mSQL, mySQL,
Oracle, Sybase, PostgreSQL e vrios outros.

Tem suporte a outros servios atravs de protocolos como IMAP, SNMP, NNTP, POP3 e,
logicamente, HTTP;

multiplataforma, tendo suporte aos sistemas Operacionais mais utilizados no mercado;

Seu cdigo livre, no preciso pagar por sua utilizao e pode ser alterado pelo usurio na
medida da necessidade de cada usurio

No precisa ser compilado.


1.4. Configurao do IIS

Antes de comearmos a trabalhar com o PHP, precisamos instalar e configurar o PHP, o MySQL e o IIS
(Internet Information Service).

Para configur-los siga as orientaes do tutorial Instalando e Configurando o PHP, IIS e MySQL que
acompanha o CD do curso de PHP.


1.5. Testando o PHP

Vamos criar um pequeno script em PHP para testarmos e verificarmos se o PHP e o IIS foram instalados e
configurados corretamente no seu computador.

Utilizando o Dreamweaver ou o Bloco de Notas, digite o script a seguir.

<html>
<head><title>Aprendendo PHP</title></head>
<body>

<?
echo "Primeiro Exemplo";
?>

</body>
</html>

Salve o arquivo como primeiro.php na pasta C:\Cursos\alunos\seudiretrio.

Agora, abra o navegador e, na barra de endereos, digite o seguinte endereo:

http://localhost/seunome/primeiro.php, onde seu nome o diretrio virtual que voc criou, lembra?

Observe que o seu browser exibiu a frase Primeiro exemplo. Sinal de que o PHP e o IIS foram instalados e
configurados corretamente no seu computador.


Apostila de PHP com MySQL

6
2. Sintaxe do PHP


2.1. Delimitando o cdigo PHP

O cdigo PHP fica embutido no prprio HTML. O interpretador identifica quando um cdigo PHP pelas
seguintes tags:

<?php
comandos;
?>

<script language=php>
comandos;
</script>

<?
Comandos;
?>

<%
comandos;
%>

O tipo de tags mais utilizado o terceiro, que consiste em uma abreviao do primeiro. Para utiliz-lo,
necessrio habilitar a opo short-tags na configurao do PHP. O ltimo tipo serve para facilitar o uso por
programadores acostumados sintaxe de ASP. Para utiliz-lo tambm necessrio habilit-lo no PHP,
atravs do arquivo de configurao php.ini.


2.2. Separador de instrues

Entre cada instruo em PHP preciso utilizar o ponto-e-vrgula, assim como em C, Perl e outras
linguagens mais conhecidas. Na ltima instruo do bloco de script no necessrio o uso do ponto-e-
vrgula, mas por questes estticas recomenda-se o uso sempre.


2.3. Comentrios

H dois tipos de comentrios em cdigo PHP:

Comentrios de uma linha:

Marca como comentrio at o final da linha ou at o final do bloco de cdigo PHP o que vier antes. Pode
ser delimitado pelo caracter # ou por duas barras ( // ). O delimitador //, normalmente, o mais utilizado.

Exemplo:

<?

echo teste; // este teste similar ao anterior
echo teste; /# este teste similar ao anterior
// sql teste;

?>

Apostila de PHP com MySQL

7
Comentrios de mais de uma linha:

Tem como delimitadores os caracteres /* para o incio do bloco e */ para o final do comentrio. Se o
delimitador de final de cdigo PHP ( ?> ) estiver dentro de um comentrio, no ser reconhecido pelo
interpretador.

Exemplo:

<?
echo teste;

/*
este um comentrio com mais de uma linha.

echo teste. Este comando echo ignorado pelo interpretador do PHP por ser um comentrio.
*/
?>


2.4. Imprimindo cdigo html


Um script php geralmente tem como resultado uma pgina html, ou algum outro texto. Para gerar esse
resultado, deve ser utilizada uma das funes de impresso, echo e print.

Sintaxes:

print(argumento);

echo (argumento1, argumento2, ... );

echo argumento;

Exemplos:

<?

$a = 10;
$b = 20;
$soma = $a + $b;

//Imprimindo a soma na tela com o comando print.

print (A soma : . $soma.<p>);

////Imprimindo a soma na tela com o comando echo.

echo (A soma : . $soma.<p>);

echo <br>;

echo $a. .$b;

?>



Apostila de PHP com MySQL

8
3 Variveis


3.1. Nomes de variveis

Toda varivel em PHP tem seu nome composto pelo caracter $(dlar) e uma string, que deve iniciar por
uma letra ou o caracter _. O PHP case sensitive, ou seja, as variveis $vivas e $VIVAS so diferentes.

Por isso preciso ter muito cuidado ao definir os nomes das variveis. bom evitar os nomes em
maisculas, pois como veremos mais adiante, o PHP j possui algumas variveis pr-definidas cujos nomes
so formados por letras maisculas.

Exemplo de variveis:

$teste = nome correto de varivel

teste= nome errado de varivel.

_teste= nome correto de varivel

Obs.: Normalmente, a varivel criada utilizando-se, na maioria das vezes, o caracter $ (dlar).


3.2. Tipos Suportados

O PHP suporta os seguintes tipos de dados:

Inteiro

Ponto flutuante

String

Array

Objeto

O PHP utiliza checagem de tipos dinmica, ou seja, uma varivel pode conter valores de diferentes tipos em
diferentes momentos da execuo do script. Por este motivo no necessrio declarar o tipo de uma
varivel para us-la. O interpretador PHP decidir qual o tipo daquela varivel, verificando o contedo em
tempo de execuo. Ainda assim, permitido converter os valores de um tipo para outro desejado,
utilizando o typecasting ou a funo settype (ver adiante).

Inteiros (integer ou long)

Uma varivel pode conter um valor inteiro com atribuies que sigam as seguintes sintaxes:

$vivas = 1234; # inteiro positivo na base decimal

$vivas = -234; # inteiro negativo na base decimal

$vivas = 0234; # inteiro na base octal-simbolizado pelo 0 equivale a 156 decimal

$vivas = 0x34; # inteiro na base hexadecimal(simbolizado pelo 0x) equivale a 52 decimal.


Apostila de PHP com MySQL

9
A diferena entre inteiros simples e long est no nmero de bytes utilizados para armazenar a varivel.
Como a escolha feita pelo interpretador PHP de maneira transparente para o usurio, podemos afirmar
que os tipos so iguais.

Ponto Flutuante (double ou float)

Uma varivel pode ter um valor em ponto flutuante com atribuies que sigam as seguintes sintaxes:

$vivas = 1.234;
$vivas = 23e4; # equivale a 230.000

Strings

Strings podem ser atribudas de duas maneiras:

a) utilizando aspas simples ( ' ) Desta maneira, o valor da varivel ser exatamente o texto contido entre
as aspas (com exceo de \\ e \' ver exemplo abaixo)

b) utilizando aspas duplas ( " ) Desta maneira, qualquer varivel ou caracter de escape ser expandido
antes de ser atribudo.

Exemplo:

<?

$teste = "Mauricio";
$vivas = '---$teste--\n';
$texto = Curso de PHP;
echo "$vivas";

?>

A sada desse script ser "---$teste--\n".

<?

$texto = Curso de PHP;
$teste = "Mauricio";
$vivas = "---$teste---\n";
echo "$vivas";

?>

A sada desse script ser "---Mauricio--" (com uma quebra de linha no final).

A tabela seguinte lista os caracteres de escape:

Sintaxe Significado

\n Nova linha
\r Retorno de carro (semelhante a \n)
\t Tabulao horizontal
\\ A prpria barra ( \ )
\$ O smbolo $
\ Aspa simples
\ Aspa dupla


Apostila de PHP com MySQL

10
Arrays

Arrays em PHP podem ser observados como mapeamentos ou como vetores indexados. Mais
precisamente, um valor do tipo array um dicionrio onde os ndices so as chaves de acesso. Vale
ressaltar que os ndices podem ser valores de qualquer tipo e no somente inteiros. Inclusive, se os ndices
forem todos inteiros, estes no precisam formar um intervalo contnuo Como a checagem de tipos em PHP
dinmica, valores de tipos diferentes podem ser usados como ndices de array, assim como os valores
mapeados tambm podem ser de diversos tipos.

Exemplo:

<?
$cor[0] = amarelo;
$cor[1] = vermelho;
$cor[2] = verde;
$cor[3] = azul;
$cor[4] = anil;
$cor[teste] = 1;
?>

Equivalentemente, pode-se escrever:

<?
$cor = array(0 => amarelo, 1 => vermelho, 2 => verde, 3 => azul, 4 => anil, teste => 1);
?>

Listas

As listas so utilizadas em PHP para realizar atribuies mltiplas.

Atravs de listas possvel atribuir valores que esto num array para variveis. Vejamos o exemplo:

Exemplo:

list($a, $b, $c) = array(a, b, c);

O comando acima atribui valores s trs variveis simultaneamente. bom notar que s so atribudos s
variveis da lista os elementos do array que possuem ndices inteiros e no negativos. No exemplo acima
as trs atribuies foram bem sucedidas porque ao inicializar um array sem especificar os ndices eles
passam a serinteiros, a partir do zero.

Um fator importante que cada varivel da lista possui um ndice inteiro e ordinal, iniciando com zero, que
serve para determinar qual valor ser atribudo. No exemplo anterior temos $a com ndice 0, $b com ndice
1 e $c com ndice 2. Vejamos um outro exemplo:

<?
$arr = array(1=>um,3=>tres,a=>letraA,2=>dois);

list($a,$b,$c,$d) = $arr;

echo $a<br>;
echo $b<br>;
echo $c<br>;
echo $d<br>;
?>


Aps a execuo do cdigo acima temos os seguintes valores:

Apostila de PHP com MySQL

11

$a == null (vazio, no aparece nada)
$b == um
$c == dois
$d == tres

Devemos observar que varivel $a no foi atribudo valor, pois no array no existe elemento com ndice 0
(zero).

Outro detalhe importante que o valor tres foi atribudo varivel $d, e no a $b, pois seu ndice 3, o
mesmo que $d na lista. Por fim, vemos que o valor letraA no foi atribudo a elemento algum da lista pois
seu ndice no inteiro.

Os ndices da lista servem apenas como referncia ao interpretador PHP para realizar as atribuies, no
podendo ser acessados de maneira alguma pelo programador.

De maneira diferente do array, uma lista no pode ser atribuda a uma varivel, servindo apenas para fazer
mltiplas atribuies atravs de um array.

Booleanos

O PHP no possui um tipo booleano, mas capaz de avaliar expresses e retornar true ou false, atravs do
tipo integer: usado o valor 0 (zero) para representar o estado false, e qualquer valor diferente de zero
(geralmente 1) para representar o estado true.


3.3. Transformao de tipos

A transformao de tipos em PHP pode ser feita das seguintes maneiras:

a) Coeres

Quando ocorrem determinadas operaes (+, por exemplo) entre dois valores de tipos diferentes, o PHP
converte o valor de um deles automaticamente (coero). interessante notar que se o operando for uma
varivel, seu valor no ser alterado.

O tipo para o qual os valores dos operandos sero convertidos determinado da seguinte forma: Se um dos
operandos for float, o outro ser convertido para float, seno, se um deles for integer, o outro ser
convertido para integer.

Exemplo:

<?

//declarao da varivel vivas
//---------------------------------------
$vivas = 1; // $vivas a string 1
$vivas = $vivas + 1;// $vivas o integer 2
$vivas = $vivas + 3.7;// $vivas o double 5.7
$vivas = 1 + 1.5 // $vivas o double 2.5

echo O valor de vivas : $vivas;

?>

Como podemos notar, o PHP converte string para integer ou double mantendo o valor. O sistema utilizado
pelo PHP para converter de strings para nmeros o seguinte:


Apostila de PHP com MySQL

12
analisado o incio da string. Se contiver um nmero, ele ser avaliado. Seno, o valor ser 0
(zero);

O nmero pode conter um sinal no incio (+ ou -);

Se a string contiver um ponto em sua parte numrica a ser analisada, ele ser considerado, e o
valor obtido ser double;

Se a string contiver um e ou E em sua parte numrica a ser analisada, o valor seguinte ser
considerado como expoente da base 10, e o valor obtido ser double;

Exemplos:

<?

$vivas = 1 + 10.5; // $vivas == 11.5
$vivas = 1 + -1.3e3; // $vivas == -1299
$vivas = 1 + teste10.5; // $vivas == 1
$vivas = 1 + 10testes; // $vivas == 11
$vivas = 1 + " 10testes"; // $vivas == 11
$vivas = 1 + "+ 10testes"; // $vivas == 1
echo O valor de vivas : $vivas;

?>

b) Transformao explcita de tipos

A sintaxe do typecast de PHP semelhante ao C: basta escrever o tipo entre parnteses antes do valor.

Exemplo:

<?

$vivas = 15; // $vivas integer (15)
$vivas = (double) $vivas // $vivas double (15.0)
$vivas = 3.9 // $vivas double (3.9)
$vivas = (int) $vivas // $vivas integer (3)
// o valor decimal truncado

echo O valor de vivas : $vivas;

?>

Os tipos permitidos na Transformao explcita so:

(int), (integer) ----------------- = muda para integer;

(real), (double), (float) ------ = muda para float;

(string)-------------------------- = muda para string;

(array) -------------------------- = muda para array;

(object) ------------------------- = muda para objeto.


Com a funo settype

A funo settype converte uma varivel para o tipo especificado, que pode ser integer, double, string,
array ou object.

Apostila de PHP com MySQL

13


Sintaxe:

Settype(nomedavarivel,novo tipo da varivbel)


Exemplo:

<?

$vivas = 15; // $vivas integer
settype($vivas,double) // $vivas double
$vivas = 15; // $vivas integer
settype($vivas,string) // $vivas string

echo O valor de vivas : $vivas;

?>



Apostila de PHP com MySQL

14
4. Operadores


4.1. Operadores Aritmticos

S podem ser utilizados quando os operandos so nmeros (integer ou float). Se forem de outro tipo, tero
seus valores convertidos antes da realizao da operao. So eles:

+ adio
- subtrao
* multiplicao
/ diviso
% mdulo


4.2. Operadores de Strings

S h um operador exclusivo para strings:

. concatenao

Exemplo:

<?

$nome = Glucio;
$sobrenome = Nascimento;
echo $nome. .$sobrenome;

?>

A sada do script acima ser: Glucio Nascimento


4.3. Operadores de atribuio

Existe um operador bsico de atribuio e diversos derivados. Sempre retornam o valor atribudo. No caso
dos operadores derivados de atribuio, a operao feita entre os dois operandos, sendo atribudo o
resultado para o primeiro. A atribuio sempre por valor, e no por referncia.

= atribuio simples
+= atribuio com adio
-= atribuio com subtrao
*= atribuio com multiplicao
/= atribuio com diviso
%= atribuio com mdulo
.= atribuio com concatenao

Exemplo:

<?

$a = 7;
$a += 2; // $a passa a conter o valor 9

?>


Apostila de PHP com MySQL

15
4.4. Operadores bit a bit

Comparam dois nmeros bit a bit.

& e lgico
| ou lgico
^ ou exclusivo
~ no (inverso)
<< shift left
>> shift right


4.5. Operadores Lgicos

Utilizados para inteiros representando valores booleanos

and e lgico
or ou lgico
xor ou exclusivo
! no (inverso)
&& e lgico
|| ou lgico


Existem dois operadores para e e para ou porque eles tm diferentes posies na ordem de precedncia.


4.6. Operadores de Comparao

As comparaes so feitas entre os valores contidos nas variveis, e no as referncias. Sempre retornam
um valor booleano.

== igual a
!= diferente de
< menor que
> maior que
<= menor ou igual a
>= maior ou igual a


4.7. Operadores de Expresso condicional

Existe um operador de seleo que ternrio. Funciona assim:

(expressao1)?(expressao2):(expressao3)

O interpretador PHP avalia a primeira expresso. Se ela for verdadeira, a expresso retorna o valor de
expresso2. Seno, retorna o valor de expresso3.


4.8. Operadores de incremento e decremento


Apostila de PHP com MySQL

16
++ incremento
decremento

Podem ser utilizados de duas formas: antes ou depois da varivel. Quando utilizado antes, retorna o valor
da varivel antes de increment-la ou decrement-la.

Quando utilizado depois, retorna o valor da varivel j incrementado ou decrementado.

Exemplos:

<?

$a = $b = 10; // $a e $b recebem o valor 10
$c = $a++; // $c recebe 10 e $a passa a ter 11
$d = ++$b; // $d recebe 11, valor de $b j incrementado

?>



Apostila de PHP com MySQL

17
5. Estruturas de Controle

As estruturas que veremos a seguir so comuns para as linguagens de programao imperativas, bastando,
portanto, descrever a sintaxe de cada uma delas, resumindo o funcionamento.


5.1. Blocos

Um bloco consiste de vrios comandos agrupados com o objetivo de relacion-los com determinado
comando ou funo. Em comandos como if, for, while, switch e em declaraes de funes blocos podem
ser utilizados para permitir que um comando faa parte do contexto desejado. Blocos em PHP so
delimitados pelos caracteres { e }. A utilizao dos delimitadores de bloco em uma parte qualquer do
cdigo no relacionada com os comandos citados ou funes no produzir efeito algum, e ser tratada
normalmente pelo interpretador.

Exemplo:

<?

if ($x == $y)
comando1;
comando2;

?>

Para que comando2 esteja relacionado ao if preciso utilizar um bloco:

<?

if ($x == $y) {
comando1;
comando2;
}

?>

5.2. Estrutura if / else / elseif

O mais trivial dos comandos condicionais o if. Ele testa a condio e executa o comando indicado se o
resultado for true (valor diferente de zero). Ele possui duas sintaxes:

Sintaxes:

if (expresso)

comando;


if (expresso) {

comando;
. . .
. . .
. . .
comando;
}

Para incluir mais de um comando no if da primeira sintaxe, preciso utilizar um bloco, demarcado por
chaves.

Apostila de PHP com MySQL

18

Exemplo 1:

<?

$a = 10;
$b = 20;

if ($a > $b)

echo o Valor de a : .$a + $b;

?>


Exemplo 2:

<?

$a = 10;
$b = 20;

if ($a >= $b) {

$media = ($a + $b) / 2;
$resto = $a % $b;//calcula o resto da diviso de A por B
echo o Valor de A : .$a <br>;
echo o Valor de B : .$b <br>;
echo o Valor da mdia : .$media <br>;
echo O resto da diviso de A por B : .$resto;
}

?>

Else

O else um complemento opcional para o if. Se utilizado, o comando ser executado se a expresso
retornar o valor false (zero). Suas duas sintaxes so:

Sintaxes:

if (expresso)
comando;
else
comando;
ou

if (expresso) {
comando 1;
comando n
else {
comando 1;
comando n
}

Exemplos:

<?

Apostila de PHP com MySQL

19

$a = 10;
$b = 20;

if ($a > $b) {
$maior = $a;
} else {

$maior = $b;
}

?>

O exemplo acima coloca em $maior o maior valor entre $a e $b.

Em determinadas situaes necessrio fazer mais de um teste, e executar condicionalmente diversos
comandos ou blocos de comandos. Para facilitar o entendimento de uma estrutura do tipo:

if (expressao1)
comando1;
else
if (expressao2)
comando2;
else
if (expressao3)
comando3;
else
comando4;

foi criado o comando, tambm opcional elseif. Ele tem a mesma funo de um else e um if usados
seqencialmente, como no exemplo acima. Num mesmo if podem ser utilizados diversos elseifs, ficando
essa utilizao a critrio do programador, que deve zelar pela legibilidade de seu script.

Elseif

O comando elseif tambm pode ser utilizado com dois tipos de sintaxe. Em resumo, a sintaxe geral do
comando if fica das seguintes maneiras:

Sintaxe:

if (expresso 1) {
comando 1;
comando n;
}
elseif (expresso 2) {
comando 1;
comando n;
}
else {
comando 1;
comando n;
if (expressao1)
comando;
elseif (expressao2)
comando;
else
comando;

ou
}


Exemplo:

<?


Apostila de PHP com MySQL

20
$nota1 = 6;
$nota 2 = 8;
$media = ($nota1 + $nota2) / 2;

if ($media > 7) {
echo Mdia: .$media .<br>;
echo Aluno aprovado.;
}
elseif ($media <7) {
echo Mdia: .$media .<br>;
echo Aluno reprovado.;
}
else {
echo Mdia: .$media.<br>;
echo Aluno em recuperao.;
}

?>


5.3. Estrutura Switch Case

O comando switch atua de maneira semelhante a uma srie de comandos if na mesma expresso.
Freqentemente o programador pode querer comparar uma varivel com diversos valores, e executar um
cdigo diferente a depender de qual valor igual ao da varivel. Quando isso for necessrio, deve-se usar o
comando switch.

Sintaxe:

swith ($valor){
case "____";
comandos;
comandos;
break;
case "____";
comandos;
comandos;
break;
case "____";
comandos;
comandos;
break;
case "____";
comandos;
comandos;
break;
default;
comandos;
comandos;
break;


O exemplo seguinte mostra dois trechos de cdigo que fazem a mesma coisa, sendo que o primeiro utiliza
uma srie de ifs e o segundo utiliza switch:

Exemplos 1: Estrutura IF

<?

Apostila de PHP com MySQL

21

if ($i == 0)
print i igual a zero;
elseif ($i == 1)
print i igual a um;
elseif ($i == 2)
print i igual a dois;

?>

Exemplo 2: Estrutura SWITCH

<?

switch ($i) {
case 0:
print i igual a zero;
break;
case 1:
print i igual a um;
break;
case 2:
print i igual a dois;
break;
}

?>

importante compreender o funcionamento do switch para no cometer enganos. O comando switch testa
linha a linha os cases encontrados, e a partir do momento que encontra um valor igual ao da varivel
testada, passa a executar todos os comandos seguintes, mesmo os que fazem parte de outro teste, at o
fim do bloco.

Por isso usa-se o comando break, quebrando o fluxo e fazendo com que o cdigo seja executado da
maneira desejada. Veremos mais sobre o break mais adiante.

Exemplo:

<?

switch ($i) {
case 0:
print i igual a zero;
case 1:
print i igual a um;
case 2:
print i igual a dois;
}

?>

No exemplo acima, se $i for igual a zero, os trs comandos print sero executados. Se $i for igual a 1,
os dois ltimos print sero executados. O comando s funcionar da maneira desejada se $i for igual a
2. Em outras linguagens que implementam o comando switch, ou similar, os valores a serem testados s
podem ser do tipo inteiro.

Em PHP permitido usar valores do tipo string como elementos de teste do comando switch. O exemplo
abaixo funciona perfeitamente:


Apostila de PHP com MySQL

22
Exemplo:

<?
switch ($s) {
case casa:
print A casa amarela;
case arvore:
print A rvore bonita;
}

?>


5.4. Estruturas de Repetio

As estruturas de repetio so utilizadas quando o programador precisa, por exemplo, repetir o mesmo
comando vrias vezes. Vamos ver as estruturas de repetio existentes.


5.4.1. While

O while o comando de repetio (lao) mais simples. Ele testa uma condio e executa um comando, ou
um bloco de comandos, at que a condio testada seja falsa. Assim como o if, o while tambm possui
duas sintaxes alternativas:

Sintaxes:

While (condio)
comando;

Ou

While (condio) {
comandos;
comandos;
}

Exemplo:

<?
$a = 0;

while($a i<= 10) {
echo $a.<br>";
$a++;
}
?>

A expresso s testada a cada vez que o bloco de instrues termina, alm do teste inicial. Se o valor da
expresso passar a ser false no meio do bloco de instrues, a execuo segue at o final do bloco. Se no
teste inicial a condio for avaliada como false, o bloco de comandos no ser executado.

O exemplo a seguir mostra o uso do while para imprimir os nmeros de 1 a 10:

<?

$i = 1;
while ($i <=10)

Apostila de PHP com MySQL

23
print $i++;
print <br>;

?>

5.4.2. Do ... While

O lao do..while funciona de maneira bastante semelhante ao while, com a simples diferena que a
expresso testada ao final do bloco de comandos.

Sintaxe:

do {
comando
. . .
comando
}
while (<condio>);

Exemplo:

<?
$a = 10;

do {
echo $a++;
echo <br>;
}
while ($a <=10)
?>


5.4.3. For

O tipo de lao mais complexo o for. Para os que programam em C, C++ ou Java, a assimilao do
funcionamento do for natural. Mas para aqueles que esto acostumados a linguagens como Pascal, h
uma grande mudana para o uso do for.

Sintaxe:

for (<inicializacao>;<condicao>;<incremento>) {
<comando>;
. . .
<comando>;
}

As trs expresses que ficam entre parnteses tm as seguintes finalidades:

Inicializao: comando ou seqncia de comandos a serem realizados antes do inicio do lao.
Serve para inicializar variveis.

Condio: Expresso booleana que define se os comandos que esto dentro do lao sero
executados ou no. Enquanto a expresso for verdadeira (valor diferente de zero) os comandos
sero executados.

Incremento: Comando executado ao final de cada execuo do lao.

Um comando for funciona de maneira semelhante a um while escrito da seguinte forma:

Apostila de PHP com MySQL

24

<inicializacao>
while (<condicao>) {
comandos
...
<incremento>
}

Exemplo:

<?
For ($a = 0, $a <10, $a++) {
Echo O valor de A : . $a;
Echo <br>;
}
?>


5.5. Quebra de fluxo


5.5.1. Break

O comando break pode ser utilizado em laos de do, for e while, alm do uso j visto no comando switch.
Ao encontrar um break dentro de um desses laos, o interpretador PHP pra imediatamente a execuo do
lao, seguindo normalmente o fluxo do script.

Exemplo 1:

<?
$x = 20;
while ($x < 0) {
if ($x == 5) {
echo Nmero invlido;
break;
}
echo Nmero .$x.<br>;
$x--;
}
?>

No trecho de cdigo acima, o lao while tem uma condio para seu trmino normal ($x <= 0), mas foi
utilizado o break para o caso de um trmino no previsto no incio do lao. Assim o interpretador seguir
para o comando seguinte ao lao.

5.5.2. Continue

O comando continue tambm deve ser utilizado no interior de laos, e funciona de maneira semelhante ao
break, com a diferena que o fluxo ao invs de sair do lao volta para o incio dele.

Exemplo:

<?

for ($i = 0; $i < 100; $i++) {

if ($i % 2)

Apostila de PHP com MySQL

25
continue;
echo $i ;
}

?>

O exemplo acima uma maneira ineficiente de imprimir os nmeros pares entre 0 e 99. O que o lao faz
testar se o resto da diviso entre o nmero e 2 0. Se for diferente de zero (valor lgico true) o interpretador
encontrar um continue, que faz com que os comandos seguintes do interior do lao sejam ignorados,
seguindo para a prxima iterao.


Apostila de PHP com MySQL

26
6. Funes


Sintaxe:

function nome_da_funo([arg1, arg2, arg3]) {
Comandos;
... ;
[return <valor de retorno>];
}

Qualquer cdigo PHP vlido pode estar contido no interior de uma funo. Como a checagem de tipos em
PHP dinmica, o tipo de retorno no deve ser declarado, sendo necessrio que o programador esteja
atento para que a funo retorne o tipo desejado. recomendvel que esteja tudo bem documentado para
facilitar a leitura e compreenso do cdigo. Para efeito de documentao, utiliza-se o seguinte formato de
declarao de funo:

tipo function nome_da_funcao(tipo arg1, tipo arg2, ...);

Este formato s deve ser utilizado na documentao do script, pois o PHP no aceita a declarao de tipos.
Isso significa que em muitos casos o programador deve estar atento aos tipos dos valores passados como
parmetros, pois se no for passado o tipo esperado no emitido nenhum alerta pelo interpretador PHP, j
que este no testa os tipos.

Valor de retorno

Toda funo pode opcionalmente retornar um valor, ou simplesmente executar os comandos e no retornar
valor algum.

No possvel que uma funo retorne mais de um valor, mas permitido fazer com que uma funo
retorne um valor composto, como listas ou arrays.

Argumentos

possvel passar argumentos para uma funo. Eles devem ser declarados logo aps o nome da funo,
entre parnteses, e tornam-se variveis pertencentes ao escopo local da funo. A declarao do tipo de
cada argumento tambm utilizada apenas para efeito de documentao.

Exemplos:

<?

function imprime($texto) {
echo $texto;
}
imprime(teste de funes);

?>

<?

function soma($v1, $v2) {
$soma = $v1+$v2;
return soma;
}

?>


Apostila de PHP com MySQL

27
Passagem de parmetros por referncia

Normalmente, a passagem de parmetros em PHP feita por valor, ou seja, se o contedo da varivel for
alterado, essa alterao no afeta a varivel original.

Exemplo:

<?

function mais8($numero) {
$numero += 8;
echo $numero. <br>;
}

$a = 3;
mais8($a); //$a continua valendo 3

echo $a;

?>

No exemplo acima, como a passagem de parmetros por valor, a funo mais8 intil, j que aps a
execuo sair da funo o valor anterior da varivel recuperado. Se a passagem de valor fosse feita por
referncia, a varivel $a teria 8 como valor.

O que ocorre normalmente que ao ser chamada uma funo, o interpretador salva todo o escopo atual, ou
seja, os contedos das variveis. Se uma dessas variveis for passada como parmetro, seu contedo fica
preservado, pois a funo ir trabalhar na verdade com uma cpia da varivel. Porm, se a passagem de
parmetros for feita por referncia, toda alterao que a funo realizar no valor passado como parmetro
afetar a varivel que o contm.

H duas maneiras de fazer com que uma funo tenha parmetros passados por referncia: indicando isso
na declarao da funo, o que faz com que a passagem de parmetros sempre seja assim; e tambm na
prpria chamada da funo.

Nos dois casos utiliza-se o modificador &. Vejamos um exemplo que ilustra os dois casos:

Exemplo:

<?

function mais5(&$num1, $num2) {
$num1 += 5;
$num2 += 5;
}

$a = $b = 1;
mais5($a, $b);

/* Neste caso, s $num1 ter seu valor alterado, pois a passagem por referncia est definida na
declarao da funo. */

mais5($a, &$b);

/* Aqui as duas variveis tero seus valores alterados. */

?>


Apostila de PHP com MySQL

28
Argumentos com valores pr-definidos (default)

Em PHP possvel ter valores default para argumentos de funes, ou seja, valores que sero assumidos
em caso de nada ser passado no lugar do argumento. Quando algum parmetro declarado desta maneira,
a passagem do mesmo na chamada da funo torna-se opcional.

Exemplo:

<?

function teste($vivas = testando) {
echo $vivas;
}

teste(); // imprime testando
teste(outro teste); // imprime outro teste

?>

bom lembrar que quando a funo tem mais de um parmetro, o que tem valor default deve ser
declarado por ltimo.

Exemplo:

<?
function teste($figura = circulo, $cor) {
echo a figura um , $figura, de cor $cor;
}

teste(azul);
?>

Contexto

O contexto o conjunto de variveis e seus respectivos valores num determinado ponto do programa. Na
chamada de uma funo, ao iniciar a execuo do bloco que contm a implementao da mesma criado
um novo contexto, contendo as variveis declaradas dentro do bloco, ou seja, todas as variveis utilizadas
dentro daquele bloco sero eliminadas ao trmino da execuo da funo.


6.1. Escopo de Variveis


O escopo de uma varivel em PHP define a poro do programa onde ela pode ser utilizada. Na maioria
dos casos todas as variveis tm escopo global.

Entretanto, em funes definidas pelo usurio um escopo local criado. Uma varivel de escopo global no
pode ser utilizada no interior de uma funo sem que haja uma declarao. Os escopos de variveis
existentes no PHP so:

Globais;
Locais;
Estticas;
Constantes;
6.2. Globais


Apostila de PHP com MySQL

29
As variveis globais so, por definio, as variveis que podem ser acessadas dentro de todo o script.
Porm, quando se cria escopo local como nas funes, precisaremos utilizar um tipo de chamada especial,
ou seja, definir aquela varivel como uma varivel global.

Exemplo:

<?

$curso = PHP;

function mostra() {

global $curso;
echo $curso;
}

mostra();

?>

Uma declarao global pode conter vrias variveis, separadas por vrgulas. Uma outra maneira de
acessar variveis de escopo global dentro de uma funo utilizando um array pr-definido pelo PHP cujo
nome $GLOBALS. O ndice para a varivel referida o prprio nome da varivel, sem o caracter $. O
exemplo acima e o abaixo produzem o mesmo resultado:

Exemplo:

<?

$curso = PHP;

function mostra() {

echo $GLOBAL[curso];
echo $curso;
}

mostra();

?>

6.3. Locais

As variveis Locais so os tipos mais restritos dentro do PHP. Elas funcionam apenas dentro desse escopo.

Exemplo:

<?
$curso = PHP;
function mostra() {
$var_local = variable local;
echo $var_local;
}
echo <b>$var_local</b>;

?>


6.4. Estticas

As variveis Estticas so variveis que possuem o mesmo tempo de vida das variveis globais, com a
diferena de funcionarem apenas em escopos locais e serem inicializadas apenas uma vez.

Apostila de PHP com MySQL

30

Exemplo:

<?
function contador() {
static $a = 0;
echo $a++.<br>;
}
for ($a = 0, $a <=5, $a++) {
contador();
}
?>


6.5. Constantes

Variveis Constantes so variveis que recebem um nico valor que no ser alterado dentro da funo,
permanecendo sempre o mesmo valor. Uma constante s pode conter valores escalares, no podendo
conter nem um array nem um objeto.

Sintaxe:

int define(string nome_da_constante, mixed valor); onde:

string nome_da_contante o nome da varivel;

mixed valor o valor que essa constante ir receber.

A funo retorna true se for bem-sucedida. Veja um exemplo de sua utilizao a seguir:

Exemplo:

define ("pi", 3.1415926536);
$circunf = 2*pi*$raio;


Apostila de PHP com MySQL

31
7. Utilizando formulrios HTML


7.1. Definindo um formulrio

Por ser uma linguagem de marcao, a sintaxe do HTML na maioria dos casos exige uma tag de incio e
uma de final daquele bloco. exatamente isso que ocorre com a definio de um formulrio: uma tag no
incio e outra no final, sendo que todos os elementos do formulrio devem estar entre as duas tags. Isto
torna possvel a incluso de mais de um formulrio num mesmo html. As tags citadas so:

<form name= action= method= enctype=>

Onde temos:

name: o identificador do formulrio. Utilizado principalmente em Scripts client-side (JavaScript);

action: nome do script que receber os dados do formulrio ao ser submetido;

method: mtodo de envio dos dados: get ou post;

enctype: formato em que os dados sero enviados. O default urlencoded. Se for utilizado um
elemento do tipo upload de arquivo (file) preciso utilizar o tipo multipart/form-data.

Exemplo:

<form action="exemplo.php" method="post">

(textos e elementos do form)

</form>

Cada elemento do formulrio deve possuir um nome que ir identific-lo no momento em que o script
indicado no ACTION for tratar os dados.

A tag <input>

Muitos elementos de um formulrio html so definidos pela tag <input>. Cada tipo de elemento possui
parmetros prprios, mas todos possuem pelo menos dois parmetros em comum: type, que define o tipo
de elemento, e name, que como j foi dito define o nome daquele elemento. Existem, ainda, outros
parmetros, tambm chamados atributos que so comuns a maioria dos campos de um formulrio. So
eles:

Value - o valor pr-definido do elemento, que aparecer quando a pgina for carregada;

Size - O tamanho do elemento na tela, em caracteres;

Maxlength - O tamanho mximo do texto contido no elemento, em caracteres;

Campo de Texto (Text)

Exibe na tela um campo para entrada de texto com apenas uma linha.

Sintaxe:

<input type="text" name="" value="" size="" maxlength="">


Apostila de PHP com MySQL

32
Campo de Texto com Mscara (Password)

Tipo de campo semelhante ao anterior, com a diferena que neste caso os dados digitados so substitudos
por asteriscos, e por isso so os mais recomendados para campos que devam conter senhas. importante
salientar que nenhuma criptografia utilizada. Apenas no aparece na tela o que est sendo digitado.

Sintaxe:

<input type="password" name="" value="" size="" maxlength="">

Checkbox

Utilizado para campos de mltipla escolha, onde o usurio pode marcar mais de uma opo.

Sintaxe:

<input type="checkbox" name="" value="" checked>

Onde:

Value - o valor que ser enviado ao servidor quando o formulrio for submetido, no caso do campo
estar marcado;

Checked - O estado inicial do elemento. Quando presente, o elemento j aparece marcado;

Radio Button

Utilizado para campos de mltipla escolha, onde o usurio pode marcar apenas uma opo. Para agrupar
vrios elementos deste tipo, fazendo com que eles sejam exclusivos, basta atribuir o mesmo nome a todos
do grupo.

Sintaxe:

<input type="radio" name="" value="" checked>

onde:

Value - o valor que ser enviado ao servidor quando o formulrio for submetido, no caso do campo
estar marcado;

Checked - O estado inicial do elemento. Quando presente, o elemento j aparece marcado;

Upload de arquivos (file)

Exibe na tela do browser um campo de texto e um boto, que ao clicado abre uma janela para localizar um
arquivo no disco. Para utilizar este tipo de componente, o formulrio dever utilizar o mtodo POST e ter o
parmetro enctype com o valor "multipart/form-data".

Sintaxe:

<form name="form1" enctype="multipart/form-data" method="post" action="">
<input type="file" name="" size="30">
</form>

Onde:

Size - O tamanho do campo de texto exibido.

TextArea


Apostila de PHP com MySQL

33
Exibe na tela uma caixa de texto, com o tamanho definido pelos parmetros cols e rows.

Sintaxe:

<textarea cols="" rows="" name="" wrap="">texto</textarea>

Onde:

Cols - nmero de colunas do campo, em caracteres;

Rows - nmero de linhas do campo, em caracteres;

Wrap - Maneira como so tratadas as quebras de linha automticas. O valor soft faz com que o
texto quebre somente na tela, sendo enviado para o servidor o texto da maneira como foi digitado;
O valor hard faz com que seja enviado para o servidor da maneira como o texto aparece na tela,
com todas as quebras de linhas inseridas automaticamente; o valor off faz com que o texto no
quebre na tela e nem quando enviado ao servidor.

Obs.: O elemento do tipo textarea no possui o parmetro value. O valor pr-definido do campo
o texto que fica entre as tags <textarea> e </textarea>.

Select

Campo utilizado para que o usurio faa a seleo a partir de uma lista de opes.

Sintaxe:

<select name="" size="" multiple>

<option value="">texto</option>
<option value="">texto</option>
<option value="">texto</option>
<option value="">texto</option>
<option value="">texto</option>
<option value="">texto</option>

</select>

Onde:

Size - nmero de linhas exibidas. Default: 1;

Multiple - parmetro que, se presente, permite que sejam selecionadas duas ou mais linhas,
atravs das teclas Control ou Shift;

Option - Cada item do tipo option acrescenta uma linha ao select;

Value - Valor a ser enviado ao servidor se aquele elemento for selecionado. Default: o texto do item;

Texto - valor a ser exibido para aquele item. No definido por um parmetro, mas pelo texto que
fica entre as tags <option> e </option>

Se o parmetro size tiver o valor 1 e no houver o parmetro multiple, exibe na tela uma combo box.
Caso contrrio, exibe na tela uma select list.

Hidden


Apostila de PHP com MySQL

34
Campo oculto que utilizado para se passar parmetros para o servidor. Este campo no visvel para o
usurio.

Sintaxe:

<input type="hidden" name="" value="">

Onde:

Value - o parmetro que ser passado para o servidor.

Submit Button

Utilizado para enviar os dados do formulrio para o script descrito na seo action da definio do
formulrio

Sintaxe:

<input type="submit" name="" value="">

Onde:

Value - o texto que aparecer no corpo do boto.

Reset Button

Utilizado para fazer todos os campos do formulrio retornem ao valor original, quando a pgina foi
carregada. Bastante utilizado como boto limpar, mas na realidade s limpa os campos se todos eles tm
como valor uma string vazia.

Sintaxe:

<input type="reset" name="" value="">

Onde:

Value - o texto que aparecer no corpo do boto.

Button

Utilizado normalmente para ativar funes de scripts client-side (JavaScript, por exemplo). Sem essa
utilizao, no produz efeito algum.

Sintaxe:

<input type="button" name="" value="">

Onde:

Value - o texto que aparecer no corpo do boto.

No prximo tpico vamos ver como fazer para criar a interao do PHP com os formulrios. Vamos ver
como manipular dados do formulrio com o PHP.


Apostila de PHP com MySQL

35
7.2. Interagindo o PHP com os Formulrios HTML


O que voc dever observar quando criar seus formulrios para manipular dados no PHP:

Seu formulrio deve conter um boto "SUBMIT" para poder enviar as informaes;

Todos os campos do formulrio que sero tratados no script PHP devem conter o parmetro
"NAME", caso contrrio, os dados no sero passados para o script PHP;

Como as informaes do formulrio so passadas para esse script PHP e como as informaes do
formulrio enviado so tratadas, dependem de voc. Existem 2 mtodos como as informaes podem ser
passadas: GET e POST. O recomendvel sempre, para todos os formulrios usar o mtodo POST, onde
os dados enviados no so visveis nas URLs, ocultando possveis importantes informaes e permitindo o
envio de longas informaes. O GET totalmente o contrrio disso.


7.3. Varivel $_POST

Esta varivel utilizada para receber as variveis vindas do formulrio pelo mtodo post.

Sintaxe:

$_POST[campo_do_formulrio]

onde:

campo_do_formulrio o campo que foi criado no formulrio que se deseja recuperar.

Exemplo:

<?
$_POST[campo1];
?>

Vamos ver um outro exemplo utilizando um formulrio HTML e um script PHP que recebe os dados do
formulrio.

<form action="script.php" method="post">

Campo 1: <input type=text name=campo1><br>
Campo 2: <input type=text name=campo2><br>
<input type=submit value="OK">

</form>

O formulrio acima usa o mtodo POST para envio das informaes, ento em PHP, teremos o seguinte
script:

<?
echo "O valor de CAMPO 1 : " . $_POST["campo1"];
echo "<br>O valor de CAMPO 2 : " . $_POST["campo2"];
?>

Se o formulrio tivesse sido enviado usando o mtodo GET, voc simplesmente usaria $_GET no lugar de
$_POST.


Apostila de PHP com MySQL

36
Vamos criar um pequeno exemplo de como se trabalhar com formulrios no PHP. Nossa pgina ir enviar
os dados de um formulrio para o servidor e exibir esses mesmos dados numa pgina de resposta criada
em PHP.

O formulrio que iremos montar a seguir (pgina form1.html) ir solicitar que voc preencha alguns dados.
Ao clicar num boto submit, o que voc digitou e preencheu no formulrio, ser enviado ao servidor
especificado para que possa ser produzida uma resposta, no nosso caso, ao arquivo RespForm1.php . O
PHP trata esses valores como variveis, cujo nome o nome do campo definido no formulrio. O exemplo
abaixo, mostra tambm que o cdigo PHP pode ser inserido em qualquer parte do cdigo HTML.

Digite o cdigo HTML a seguir (form1.html)

<html>
<head><title>Curso de PHP com MySQL</title></head>
<body>
<form name="form1" method="get" action="RespForm1.php">
<p>Nome:<br>
<input name="nome" type="text" id="nome" size="30" maxlength="30"></p>
<p>Senha:<br><input name="senha" type="password" id="senha" size="10" maxlength="10"></p>
<p>Sexo:<br>
<input name="sexo" type="radio" value="Masculino">Masculino
<input name="sexo" type="radio" value="Feminino">Feminino</p>
<p>Selecione o Turno:<br>

<input name="turno" type="checkbox" id="turno" value="Manh">Manh
<input name="turno" type="checkbox" id="turno" value="Tarde">Tarde
<input name="turno" type="checkbox" id="turno" value="Noite">Noite</p>

<p>Cidade:<br>
<select name="cidade" id="cidade">

<option value="vazio"> </option>
<option value="Rio">Rio de Janeiro</option>
<option value="So Paulo">So Paulo</option>
<option value="Belo Horizonte">Belo Horizonte</option>

</select></p>
<p><input type="submit" value="Enviar"></p>
<input type='hidden' name='btnOK' value='1'>
</form>
</body>
</html>
Salve o arquivo na sua pasta com o nome Form1.html. Agora, vamos criar o arquivo RespForm1.php.

Arquivo RespForm1.php

Apostila de PHP com MySQL

37

<?

// Recebe os dados do formulrio com a varivel $_POST

$nome = $_POST["nome"];
$senha = $_POST["senha"];
$sexo = $_POST["sexo"];
$turno = $_POST["turno"];
$cidade = $_POST["cidade"];

// Exibe os dados na pgina de resposta: RespForm.php

echo "Os dados recebidos do formulrio so: <p>";
echo "
<table width = '400' border='1' cellspacing='0' cellpadding='0'>
<tr>
<td width = '100'>Nome:<td>
<td width = '300'>$nome</td>
</tr>
<tr>
<td width = '100'>Senha:<td>
<td width = '300'>$senha</td>
</tr>
<tr>
<td width = '100'>Sexo:<td>
<td width = '300'>$sexo</td>
</tr>
<tr>
<td width = '100'>Turno:<td>
<td width = '300'>$turno</td>
</tr>
<tr>
<td width = '100'>Cidade:<td>
<td width = '300'>$cidade</td>
</tr>
</table>
";

?>

<html>
<head><title>Curso de PHP</title>
</head>
<body>
<p><font face="Arial, Helvetica, sans-serif" size="4">
<a href="form1.html">Clique aqui para voltar ao formul&aacute;rio.</a>
</font>
</body>
</html>

Aps salvar os arquivos Form1.html e RespForm1.php, abra o browser e, na linha de endereo digite:


Apostila de PHP com MySQL

38
http://localhost/seudiretorio(o diretrio virtual criado no IIS)/Form1.html.

Voc ver apenas um formulrio que contem os campos para voc preencher, conforme mostra a figura 01
a seguir.

Figura 1

Aps preencher o formulrio, clique no boto Enviar para submeter este formulrio ao servidor. Uma nova
pgina, que a resposta do servidor, dever aparecer conforme mostra a figura 2 a seguir.


Figura 2


Apostila de PHP com MySQL

39
Observaes:

Em vez de usar $_GET ou $_POST voc pode escrever a varivel com o mesmo nome do campo do
formulrio (no exemplo, $campo1 e $campo2). Mas, esse uso no recomendado, pois se a diretiva
"register_globals" na configurao do seu PHP estiver desativada, as variveis com nome dos campos dos
formulrios, tero um valor vazio.

Uma soluo para isso usar a funo import_request_variables no comeo dos seus scripts que
interpretam formulrios. Essa funo aceita 3 letras como argumentos: P, G e C, referentes a $_POST,
$_GET e $_COOKIE respectivamente.

Exemplo:

<?

import_request_variables("gP");

?>

O que acontece?

Exemplo:

Voc possui formulrio com os campos "nome", "endereo" e "idade". Assuma que a diretiva
"register_globals" do seu PHP esteja desligada, mas, voc j havia programado o script usando as
variveis no escopo global, no lugar de $_POST.

Adicionando aquela funo no comeo do script, as variveis do seu formulrio postado:

$_POST["nome"], $_POST["endereco"] e $_POST["idade"] sero extradas cada para uma varivel
diferente: $nome, $endereco e $idade.


Apostila de PHP com MySQL

40
8. Trabalhando com MySQL


O MySQL surgiu a partir da necessidade da equipe que criou o SGBD, de utilizar algum mecanismo que
permitisse a conexo de tabelas criadas na linguagem SQL para um determinado fim. A princpio, o grupo
iria utilizar o mSQL, mas logo perceberam que esta ferramenta no era rpida o suficiente para atender s
necessidades do projeto. O jeito foi criar uma soluo prpria. Nascia o MySQL.

O MySQL foi criado por Michael Widenius na companhia sua TcX. Por volta de 1979 Michael desenvolveu
um banco de dados chamado UNIREG, sendo rescritos em vrias linguagens desde ento" [YAR 99]. Em
1994, a empresa TcX comeou o desenvolvimento de aplicaes baseadas na Web, tendo como base o
banco UNIREG, porm esse banco possua muito "overhead" para obter sucesso em uma aplicao para
gerao de pginas dinmicas na Web. Ento a empresa TcX comeou a procurar por outro banco o mSQL,
uma ferramenta baseada em SQL mas com caractersticas pobres no possuindo por exemplo suporte a
ndices, e com desempenho inferior ao UNIREG.

Foi ento que o desenvolvedor do banco UNIREG contatou o David Hughes criador do mSQL, para saber
do interesse dele em unir os dois bancos. Sendo positivo o interesse de David , a empresa TcX resolveu
desenvolver um novo banco, mas mantendo ao mximo a compatibilidade com mSQL. TcX foi esperta o
suficiente para no reinventar o que j estava bem feito, ela construiu seu servidor baseado na estrutura
que j estava montada do UNIREG e utilizou grande nmero de utilitrios escritas para mSQL e fez API's
para o novo servidor praticamente iguais ao mSQL. Como resultado usurios do mSQL que decidissem
mudar para o novo servidor da TcX, teriam apenas que fazer pequenas e simples mudanas nos cdigos
existentes.

Ento foi em maio de 1995 que, definitivamente, a primeira verso do MySQL foi lanada. Um dos parceiros
da TcX sugeriu a distribuio do servidor na Internet, o objetivo disso era a utilizao de um modelo pioneiro
desenvolvido por Aladdin Peter Deutsch. O resultado foi um maior flexibilidade em sem "copyright", que fez
do MySQL mais difundido gratuitamente do que mSQL.


8.1. O Banco de Dados MySQL

O MySQL foi desenvolvido pela TCX em 1996. Atualmente a MySQL AB desenvolve o programa. MySQL
AB a companhia dos fundadores e principais desenvolvedores do MySQL. Eles criaram-no porque
precisavam de um banco de dados relacional que pudesse tratar grandes quantidades de dados em
mquinas de custo relativamente barato.

um dos bancos de dados relacionais mais rpidos do mercado, apresenta quase todas as funcionalidades
dos grandes bancos de dados . MySQL uma linguagem simples, em que voc facilmente pode gravar,
alterar e recuperar informaes num web site com segurana e rapidez O MYSQL executado,
principalmente, em sistemas que participam da filosofia UNIX, embora outros sistemas S.O tambm
fornecem suporte, como Windows, por exemplo.

O Servidor MySQL foi desenvolvido originalmente para lidar com bancos de dados muito grandes de
maneira muito mais rpida que as solues existentes e tem sido usado em ambientes de produo de alta
demanda por diversos anos de maneira bem sucedida. Apesar de estar em constante desenvolvimento, o
Servidor MySQL oferece hoje um rico e proveitoso conjunto de funes. A conectividade, velocidade, e
segurana fazem com que o MySQL seja altamente adaptvel para acessar bancos de dados na Internet.

O Programa de Banco de Dados MySQL um sistema cliente/servidor que consiste de um servidor SQL
multitarefa que suporta acessos diferentes, diversos programas clientes e bibliotecas, ferramentas
administrativas e diversas interfaces de programao (API's). Tambm concedemos o Servidor MySQL
como uma biblioteca multitarefa que voc pode ligar sua aplicao para chegar a um produto mais rpido,
menor e mais facilmente gerencivel.


Apostila de PHP com MySQL

41
8.2. Caractersticas do MySQL


Multi-plataforma, portanto suporta diferentes plataformas: Win32, Linux, FreeBSD, Unix, etc...

Suporte a mltiplos processadores

Um sofisticado sistema de senhas criptografadas flexvel e Seguro.

Suporta at 16 ndices por tabela

Cdigo fonte escrito em C e C++ e testado com uma variedade de diferentes compiladores

As tabelas criadas podem ter tamanho de at 4 GB

Banco de dados de cdigo aberto e gratuito

Suporte as APIs das Seguintes linguagens: PHP, Perl, C,C++,Java, Pynthon, etc...

Suporte ODBC, voc pode facilmente conectar o Access a um banco de dados do MySQL

O Cliente conecta no MySQL atravs de conexes TCP/IP.

Nenhum problema com o Y2K, visto que o MySQL usa o relgio do Unix que no apresentar
problemas at 2069

Capacidade para manipular bancos com at 50 milhes de registros

Reduz a administrao, engenharia e a sustentao custa por at 50%


8.3. O que o MySQL faz de melhor

Aplicaes Web

Suporte a cdigo fonte aberto

Requisitos de sistema baixo

Tabelas com tamanho grande

Estabilidade


8.3. O MySQL gratuito ?

Pessoas confundem "free" com "grtis" o que comum aqui no Brasil. Mas em se tratando de software este
"free" de open source e no gratuito.

Para poder utilizar o MySQL sob a licena GPL e no precisar pagar, o produto desenvolvido precisa ser
GPL tambm, seno, orientamos a compra da licena comercial, com baixo custo, sendo comercializada por
servidor, sem limites de usurios e processadores e ainda com garantia perptua de atualizao de verso
para o resto da vida.


Apostila de PHP com MySQL

42
8.4. Tipos de dados do MySQL

Os tipos de dados que pode ter um campo, podem-se agrupar em trs grandes grupos:

1. Tipos numricos
2. Tipos de Data
3. Tipos de Cadeia


1) Tipos numricos:

Existem tipos de dados numricos, que se podem dividir em dois grandes grupos, os que esto em vrgula
flutuante (com decimais) e os que no.

TinyInt: um nmero inteiro com ou sem sinal. Com sinal a margem de valores vlidos desde -128 at
127. Sem sinal, a margem de valores de 0 at 255

SmallInt: nmero inteiro com ou sem sinal. Com sinal a margem de valores vlidos desde -32768 at
32767. Sem sinal, a margem de valores de 0 at 65535.

MediumInt: nmero inteiro com ou sem sinal. Com sinal a margem de valores vlidos desde -8.388.608
at 8.388.607. Sem sinal, a margem de valores de 0 at 16777215.

Int: nmero inteiro com ou sem sinal. Com sinal a margem de valores vlidos desde -2147483648 at
2147483647. Sem sinal, a margem de valores de 0 at 429.496.295

BigInt: nmero inteiro com ou sem sinal. Com sinal a margem de valores vlidos desde -
9.223.372.036.854.775.808 at 9.223.372.036.854.775.807. Sem sinal, a margem de valores de 0 at
18.446.744.073.709.551.615.

Float: nmero pequeno em vrgula flutuante de preciso simples. Os valores vlidos vo desde -
3.402823466E+38 at -1.175494351E-38,0 et desde 175494351E-38 at 3.402823466E+38.

Double: nmero em vrgula flutuante de dupla preciso. Os valores permitidos vo desde -
1.7976931348623157E+308 at -2.2250738585072014E-308, 0 e desde 2.2250738585072014E-308 at
1.7976931348623157E+308

Decimal: Nmero em vrgula flutuante desempacotado. O nmero armazena-se como uma cadeia.


Tipo de Campo Tamanho de Armazenamento
TINYINT 1 byte
SMALLINT 2 bytes
MEDIUMINT 3 bytes
INT 4 bytes
BIGINT 8 bytes
INTEGER 4 bytes
BIGINT 8 bytes
FLOAT 4 bytes
DOUBLE 8 bytes
DECIMAL(M,D) M+2 bytes se D > 0, M+1 bytes se D = 0


2) Tipos data:

Apostila de PHP com MySQL

43

Na hora de armazenar datas, h que ter em conta que MySQL no verifica de uma maneira estricta se uma
data vlida ou no. Simplesmente comprova que o ms est compreendido entre 0 e 12 e que o dia est
compreendido entre 0 e 31.

Date: tipo data, armazena uma data. A margem de valores vai desde o 1 de Janeiro de 1001 ao 31 de
dezembro de 9999. O formato de armazenamento de ano-mes-dia.

DateTime: Combinao de data e hora. A margem de valores vai desde o 1 ed Janeiro de 1001 s 0 horas,
0 minutos e 0 segundos ao 31 de Dezembro de 9999 s 23 horas, 59 minutos e 59 segundos. O formato de
armazenamento de ano-mes-dia horas:minutos:segundos

TimeStamp: Combinao de data e hora. A margem vai desde o 1 de Janeiro de 1970 ao ano 2037. O
formato de armazenamento depende do tamanho do campo:

Tamanhodo campo Formato
14 AnoMesDiaHoraMinutoSegundo aaaammddhhmmss
12 AnoMesDiaHoraMinutoSegundo aammddhhmmss
8 AnoMesDia aaaammdd
6 AnoMesDia aammdd
4 AnoMes aamm
2 Ano aa

Time: armazena uma hora. A margem de horas vai desde -838 horas, 59 minutos e 59 segundos. O formato
de armazenamento 'HH:MM:SS'.

Year: armazena um ano. A margem de valores permitidos vai desde o ano 1901 ao ano 2155. O campo
pode ter tamanho dois ou tamanho 4 dependendo de se queremos armazenar o ano com dois ou quatro
algarismos.
Tipo de Campo Tamanho de Armazenamento
DATE 3 bytes
DATETIME 8 bytes
TIMESTAMP 4 bytes
TIME 3 bytes
YEAR 1 byte

3 Tipos de cadeia:

Char(n): armazena uma cadeia de longitude fixa. A cadeia poder conter desde 0 at 255 caracteres.

VarChar(n): armazena uma cadeia de longitude varivel. A cadeia poder conter desde 0 at 255
caracteres. Dentro dos tipos de cadeia pode-se distinguir dois subtipos, os tipo Test e os tipo Blob (Binary
Large Object) A diferena entre um tipo e outro o tratamento que recebem na hora de orden-los e
compar-los. No tipo test ordena-se sem ter importncia as maisculas e as minsculas e no tipo blob
ordena-se tendo em conta as maisculas e minsculas.

TinyText e TinyBlob: Coluna com uma longitude mxima de 255 caracteres.

Blob e Text: um texto com um mximo de 65535 caracteres.

MediumBlob e MediumText: um texto com um mximo de 16.777.215 caracteres.

LongBlob e LongText: um texto com um mximo de caracteres 4.294.967.295. H que ter em conta que
devido aos protocolos de comunicao os pacotes podem ter um mximo de 16 Mb.

Apostila de PHP com MySQL

44

Enum: campo que pode ter um nico valor de uma lista que se especifica. O tipo Enum aceita at 65535
valores diferentes.

Tipo de campo Tamanho de Armazenamento
CHAR(n) n bytes
VARCHAR(n) n +1 bytes
TINYBLOB, TINYTEXT Longitude+1 bytes
BLOB, TEXT Longitude +2 bytes
MEDIUMBLOB, MEDIUMTEXT Longitude +3 bytes
LONGBLOB, LONGTEXT Longitude +4 bytes
ENUM('value1','value2',...) 1 dos bytes dependendo do nmero de valores



Apostila de PHP com MySQL

45
8.5. Comandos Bsicos do SQL

Iremos ver os comandos bsicos do SQL, utilizados pela maioria dos bancos de dados , inclusive o MySQL,
que sero necessrios para o desenvolvimento do nosso projeto, pois o objetivo deste curso no aprender
o SQL, mas sim, o PHP.

Observe que todo comando SQL termina com um ; (ponto e vrgula).


Comando Create Database

Este comando permite a criao do banco de dados.

Sintaxe:

CREATE DATABASE < nome_db >;

onde:

nome_db - indica o nome do Banco de Dados a ser criado.

Exemplo:

Create database focus;


Comando Create Table

Este comando permite a criao de tabelas no banco de dados.

Sintaxe:

CREATE TABLE < nome_tabela > (
nome_atributo1 < tipo > [ NOT NULL ],
nome_atributo2 < tipo > [ NOT NULL ],
......
nome_atributoN < tipo > [ NOT NULL ]
) ;

onde:

nome_table - indica o nome da tabela a ser criada.

nome_atributo - indica o nome do campo a ser criado na tabela.

tipo - indica a definio do tipo de atributo ( integer(n), char(n), ... ).

Exemplo:

Create table alunos (
Id_aluno UNSIGNED INT(3) NOT FULL,
nome CHAR(40) NOT NULL,
endereco CHAR (50) NOT FULL
turma CHAR(20) NOT NULL,
PRIMARY KEY (matricula)
);


Apostila de PHP com MySQL

46
Comando Drop

Este comando elimina a definio da tabela, seus dados e referncias.

Sintaxe:

DROP TABLE < nome_tabela > ;

Exemplo:

Drop table alunos;


Comando Alter

Este comando permite inserir/eliminar atributos nas tabelas j existentes.

Sintaxe:

ALTER TABLE < nome_tabela > ADD / DROP (
nome_atributo1 < tipo > [ NOT NULL ],
nome_atributoN < tipo > [ NOT NULL ]
) ;

Exemplo:

Alter table alunos ADD COLUMN turno char(10) NOT NULL;


8.6. Manipulando dados das tabelas

Comando SELECT

Permite recuperar informaes existentes nas tabelas.

Sintaxe:

SELECT [DISTINCT] expressao [AS nom-atributo] [FROM from-list] [WHERE condicao] [ORDER BY
attr_name1 [ASC | DESC ]

onde:

DISTINCT - Para eliminar linhas duplicadas na sada.
Expresso - Define os dados que queremos na sada, normalmente uma ou mais colunas de uma
tabela da lista FROM.
AS nom-atributo - um alias para o nome da coluna, exemplo:
FROM - lista das tabelas na entrada
WHERE - critrios da seleo
ORDER BY - Critrio de ordenao das tabelas de sada. Podem ser:
ASC - ordem ascendente (crescente);
DESC - ordem descendente (decrescente)

Exemplo:

Select cidade, estado from brasil where populacao > 100000 order by Desc;

Comando INSERT


Apostila de PHP com MySQL

47
Adiciona um ou vrios registros a uma tabela. Isto referido como consulta anexao.

Sintaxe:

INSERT INTO destino [(campo1[, campo2[, ...]])]
VALUES (valor1[, valor2[, ...])

Onde;

Destino - O nome da tabela ou consulta em que os registros devem ser anexados.

campo1, campo2 - Os nomes dos campos aos quais os dados devem ser anexados

valor1, valor2 - Os valores para inserir em campos especficos do novo registro. Cada valor
inserido no campo que corresponde posio do valor na lista: Valor1 inserido no campo1 do
novo registro, valor2 no campo2 e assim por diante.

Os valores devem ser separados com uma vrgula e os campos de textos entre aspas duplas ou simples.

Exemplo:

Insert into alunos (Id_aluno, nome, endereo, turma, turno)
Values (1, Glaucio, Av. das Amricas, 1101, manh);


Comando UPDATE

Cria uma consulta atualizao que altera os valores dos campos em uma tabela especificada com base em
critrios especficos.

Sintaxe:

UPDATE tabela SET campo1 = valornovo, ... WHERE critrio;

Onde:

Tabela - O nome da tabela cujos dados voc quer modificar.

Valornovo - Uma expresso que determina o valor a ser inserido em um campo especfico nos
registros atualizados.

critrio - Uma expresso que determina quais registros devem ser atualizados. S os registros que
satisfazem a expresso so atualizado.

Exemplo:

Update alunos Set turno = tarde where turma = 1101;

UPDATE especialmente til quando voc quer alterar muitos registros ou quando os registros que voc
quer alterar esto em vrias tabelas. Voc pode alterar vrios campos ao mesmo tempo.

UPDATE no gera um conjunto de resultados. Se voc quiser saber quais resultados sero alterados,
examine primeiro os resultados da consulta seleo que use os mesmos critrios e ento execute a
consulta atualizao.

Comando DELETE

Remove registros de uma ou mais tabelas listadas na clusula FROM que satisfaz a clusula WHERE.

Apostila de PHP com MySQL

48

Sintaxe:

DELETE [tabela.*]
FROM tabela
WHERE critrio

onde:

tabela.* - O nome opcional da tabela da qual os registros so excludos.

tabela - O nome da tabela da qual os registros so excludos.

critrio - Uma expresso que determina qual registro deve ser excludo.

Exemplo:

Delete from alunos WHERE turno='Manh';

DELETE especialmente til quando voc quer excluir muitos registros.

Para eliminar uma tabela inteira do banco de dados, voc pode usar o mtodo Execute com uma instruo
DROP.

Entretanto, se voc eliminar a tabela, a estrutura perdida. Por outro lado, quando voc usa DELETE,
apenas os dados so excludos. A estrutura da tabela e todas as propriedades da tabela, como atributos de
campo e ndices, permanecem intactos.

Voc pode usar DELETE para remover registros de tabelas que esto em uma relao um por vrios com
outras tabelas. Operaes de excluso em cascata fazem com que os registros das tabelas que esto no
lado "vrios" da relao sejam excludos quando os registros correspondentes do lado "um" da relao so
excludos na consulta.

Por exemplo, nas relaes entre as tabelas Clientes e Pedidos, a tabela Clientes est do lado "um" e a
tabela Pedidos est no lado "vrios" da relao. Excluir um registro em Clientes faz com que os registros
correspondentes em Pedidos sejam excludos se a opo de excluso em cascata for especificada.

O DELETE exclui registros inteiros e no apenas dados em campos especficos. Se voc quiser excluir
valores de um campo especfico, crie uma consulta atualizao que mude os valores para Null.

Aps remover os registros usando uma consulta excluso, voc no poder desfazer a operao. Se quiser
saber quais arquivos foram excludos, primeiro examine os resultados de uma consulta seleo que use o
mesmo critrio e ento, execute a consulta excluso. Mantenha os backups de seus dados. Se voc excluir
os registros errados, poder recuper-los a partir dos seus backups.


Apostila de PHP com MySQL

49
9. Conexo com o MySQL via PHP


Todos os exemplos e arquivos do nosso projeto referentes a acesso de banco de dados utilizaro o
gerenciador de banco de dados MySQL que encontra-se disponvel no CD que acompanha este curso de
PHP. Estamos utilizando a verso 5.x do MySQL. No CD esto disponveis as verses 4.x e 5.x.

Para interagir com uma base de dados SQL existem trs comandos bsicos que devem ser utilizados: um
que faz a conexo com o servidor de banco de dados, um que seleciona a base de dados a ser utilizada e
um terceiro que executa uma query (consulta) SQL. Existe, ainda, um quarto comando que pode ou ser
utilizado, que o comando que fecha a conexo com o banco de dados.

So eles:


9.1. Abrindo e fechando conexo com o MySQL


Mysql_connect( )

Comando utilizado para criar a conexo com a base de dados num servidor mySQL.

O comando mysql_pconnect tambm pode ser utilizado para criar a conexo. A diferena entre os dois
comandos que o mysql_pconnect estabelece uma conexo permanente, ou seja, que no encerrada
ao final da execuo do script. Utilizaremos a primeira opo: mysql_connect.

Sintaxe:

mysql_connect(string [host[:porta]] , string [login] , string [senha] ) [ or die (mensagem de erro)];

onde:

string [host[:porta]] o endereo do servidor, onde o banco est armazenado;

string [login] o usurio do banco de dados;

string [senha] a senha do usurio do banco de dados MySQL.

die parmetro opcional que exibe uma mensagem indicando que a conexo no foi efetuada.

Exemplo:

<?
$conexao = mysql_connect (localhost, root, focus) or die (Conexo no efetuada);
?>

O valor de retorno um inteiro que identifica a conexo, ou falso se a conexo falhar. Antes de tentar
estabelecer uma conexo, o interpretador PHP verifica se j existe uma conexo estabelecida com o
mesmo host, o mesmo login e a mesma senha. Se existir, o identificador desta conexo retornado. Seno,
uma nova conexo criada.

Assim, se a conexo for bem sucedida (existir um servidor no endereo especificado que possua o usurio
com a senha fornecida), o identificador da conexo fica armazenado na varivel $conexao, caso contrrio
ser mostrada a mensagem Conexo no efetuada.


Mysql_close( )

Apostila de PHP com MySQL

50

Comando utilizado para encerrar uma conexo estabelecida com o comando mysql_connect antes de
chegar ao final do script. Caso esse comando no seja utilizado a conexo encerrada no final do script.

Sintaxe:

mysql_close(int [string da conexo] );

Se o identificador no for fornecido, a ltima conexo estabelecida ser encerrada.

Exemplo:

<?

mysql_close ($conexao);

?>

Obs.: O comando mysql_close no encerra conexes estabelecidas com o mysql_pconnect.


Mysql_select_db( )

Comando utilizado para selecionar a base de dados depois que a conexo for estabelecida. Se nenhuma de
conexo especificado, a ultima conexo aberta assumida. Se nenhuma conexo esta aberta, a funo
ir tentar abrir uma conexo como se mysql_connect() fosse chamada sem argumentos e us-la.

Sintaxe:

mysql_select_db(banco de dados, [string de conexao]) or die [(mensagem)];

Onde:

banco de dados o banco de dados que ser utililzado;

string de conexo a conexo criada com o servidor MySQL.

die parmetro opcional que exibe uma mensagem indicando que a conexo no foi efetuada.


Exemplo:

<?

$conexao = mysql_connect(localhost, root, focus);

if ($conexao) {
die (Conexo no estabelecida);
}

db_select = mysql_select_db(focus, $conexao);

?>


Apostila de PHP com MySQL

51
Mysql_query( )


Este comando utilizado para realizar uma consulta SQL no MySQL.

Sintaxe:

Mysql_query(string da consulta);

Onde:

String da consulta um dos comandos utilizados do SQL para efetuar uma consulta, uma incluso, uma
alterao ou uma excluso no banco de dados.

O comando mysql_query() envia uma query (consulta) para o banco de dados ativo no servidor da conexo
informada em string da consulta. Se o parmetro string da consulta no especificado, a ultima conexo
aberta usada. Se nenhuma conexo esta aberta, a funo tenta estabelecer uma conexo como
mysql_connect() seja chamada sem argumentos e us-la. O resultado guardado em buffer.

Exemplo:

<?

sql = select * from alunos where id_aluno = 10;

mysql_query (sql);

?>

Vamos ver um exemplo de um script PHP utilizando os comandos vistos acima que cria uma conexo com o
banco de dados Focus, seleciona a tabela alunos e insere alguns dados na tabela.

<?
$conexao = mysql_connect (localhost, root, focus);
mysql_select_db(focus, $conexo);

$insere = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (1, Glaucio, Av. das Amricas, 1101, manh);

$insere1 = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (2, Alexandre, Av. das Amricas, 1101, tarde);

$insere2 = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (3, Lucinaldo, Av. das Amricas, 1101, tarde);

mysql_query ($insere, $conexao) or die (No foi possvel executar a insero.);
mysql_query ($insere1, $conexao) or die (No foi possvel executar a insero.);
mysql_query ($insere2, $conexao) or die (No foi possvel executar a insero.);

$delete = Delete from alunos where turno = tarde);

mysql_query ($delete, $conexao);

echo ( todos os alunos do turno da tarde foram excludos.);
mysql_close ($conexao);
?>


Apostila de PHP com MySQL

52
9.2. Tratamento de resultados de query Select


Ao executar uma query SQL SELECT atravs do comando mysql_query, o identificador do resultado deve
ser armazenado numa varivel que pode ser tratada de diversas formas. Duas maneiras interessantes de
faz-lo usam um dos comandos a seguir: mysql_result, mysql_fetch_row ou mysql_fetch_array.

Mysql_result( )

Esta funo retorna o resultado de uma query SQL.

Sintaxe:

mysql_result(resultado, linha, mixed [campo]);

Onde:

resultado - o identificador do resultado, obtido com o retorno da funo mysql_query;

linha - especifica o registro a ser exibido, j que uma query SELECT pode retornar diversos
registros;

campo - o identificador do campo a ser exibido, sendo o tipo descrito como mixed pela
possibilidade de ser de diversos tipos (neste caso, inteiro ou string).

Exemplo:

<?
$conexao = mysql_connect (localhost, root, focus);
mysql_select_db(focus, $conexo);

$insere = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (1, Glaucio, Av. das Amricas, 1101, manh);

$insere1 = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (2, Alexandre, Av. das Amricas, 1101, tarde);

mysql_query ($insere, $conexao) or die (No foi possvel executar a insero.);
mysql_query ($insere1, $conexao) or die (No foi possvel executar a insero.);

$consulta = Select Id_Aluno, nome, turno from alunos;
$resultado = mysql_query ($consulta, $conexao);
$nome = mysql_result($resultado,0,"nome");
$turno = mysql_result($resultado,0,turno);

echo (Nome: .$nome.<p>.Turno: .$turno);

mysql_close ($conexao);
?>

Com o exemplo acima, o resultado ser:

Nome: Glucio

Turno: Manh

Mysql_fetch_array( )


Apostila de PHP com MySQL

53
Esta funo l uma linha do resultado e devolve um array, cujos ndices so os nomes dos campos. A
execuo seguinte do mesmo comando ler a prxima linha, at chegar ao final do resultado.

Sintaxe:

Mysql_fecth_array(string da cosulta SQL);

Exemplo:

<?

$conexao = mysql_connect (localhost, root, focus);
mysql_select_db(focus, $conexo);

$insere = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (1, Glaucio, Av. das Amricas, 1101, manh);

$insere1 = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (2, Alexandre, Av. das Amricas, 1101, tarde);

mysql_query ($insere, $conexao) or die (No foi possvel executar a insero.);
mysql_query ($insere1, $conexao) or die (No foi possvel executar a insero.);

$consulta = Select Id_Aluno, nome, turno from alunos;
$resultado = mysql_query ($consulta, $conexao);

$dados = mysql_fecth_array($resultado);

$nome = $dados[nome];
$turno =$dados[turno];

echo (Nome: .$nome.<p>.Turno: .$turno);

mysql_close ($conexao);

?>

Com o exemplo acima, o resultado ser:

Nome: Glucio
Turno: Manh

Mysql_fetch_row( )

Esta funo semelhante a funo mysql_fetch_array, com a diferena que os ndices do array so
numricos, iniciando pelo 0 (zero).

Sintaxe:

Mysql_fetch_row(string de consulta);

Exemplo:

O exemplo anterior substituindo a funo mysql_fecth_array pela mysql_fetch_row.

Mysql_free_result( )

Esta funo libera a memria do resultado de uma consulta.

Apostila de PHP com MySQL

54

Sintaxe:

mysql_free_result ( resource result )

Exemplo:

<?

$conexao = mysql_connect (localhost, root, focus);
mysql_select_db(focus, $conexo);

$insere = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (1, Glaucio, Av. das Amricas, 1101, manh);

$insere1 = Insert into alunos (id_aluno, nome, endereo, turma, turno)
Values (2, Alexandre, Av. das Amricas, 1101, tarde);

mysql_query ($insere, $conexao) or die (No foi possvel executar a insero.);
mysql_query ($insere1, $conexao) or die (No foi possvel executar a insero.);

$consulta = Select Id_Aluno, nome, turno from alunos;
$resultado = mysql_query ($consulta, $conexao);

$dados = mysql_fecth_array($resultado);

$nome = $dados[nome];
$turno =$dados[turno];

echo (Nome: .$nome.<p>.Turno: .$turno);

mysql_free_result($resultado);

mysql_close ($conexao);

?>

No exemplo acima, a funo mysql_free_result( ) ir liberar toda a memria usada com o identificador de
resultado $resultado.

Obs.: mysql_free_result() somente precisa ser chamado se voc esta preocupado em quanta
memria esta sendo usada para query num grande conjunto de resultados. Toda a memria usada
do resultado liberada automaticamente ao final da execuo do script.


Apostila de PHP com MySQL

55
10. Utilizando headers


O comando header permite enviar cabealhos html para o cliente. Deve ser utilizado por usurios que
conheam a funo de cada header que pode ser enviado.

Sintaxe:

Header (string header);

Exemplo:

<?

header (location: login.php);

?>

No pode ser enviado depois de algum texto. veja o seguinte exemplo:

<html>
<? header("Location: http://www.php.net"); ?>
<body>
...

O cdigo acima causar um erro, j que tentou-se enviar um header depois de ter sido enviado um
texto(<html>\n).

Algumas utilizaes do header so:

redirecionar para outra pgina:

Exemplo:

header("Location: http://www.php.net");

Definir o script como uma mensagem de erro:

Exemplo:

header("http/1.0 404 Not Found");

Definir a expirao da pgina:

Exemplos:

header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Pragma: no-cache"); // HTTP/1.0


Apostila de PHP com MySQL

56
11. Utilizando cookies


11.1. O que so Cookies


Cookies so variveis gravadas no cliente(browser) por um determinado site. Somente o site que gravou o
cookie pode ler a informao contida nele. Este recurso muito til para que determinadas informaes
sejam fornecidas pelo usurio apenas uma vez. Exemplos de utilizao de cookies so sites que informam a
quantidade de vezes que voc j visitou, ou alguma informao fornecida numa visita anterior.

Existem cookies persistentes e cookies de sesso. Os persistentes so aqueles gravados em arquivo, e que
permanecem aps o browser ser fechado, e possuem data e hora de expirao. Os cookies de sesso no
so armazenados em disco e permanecem ativos apenas enquanto a sesso do browser no for encerrada.

Por definio, existem algumas limitaes para o uso de cookies, listadas a seguir:

300 cookies no total

4 kilobytes por cookie.

20 cookies por servidor ou domnio.


11.2. Gravando cookies

Para gravar cookies no cliente, deve ser utilizada a funo setcookie.

Sintaxe:

setcookie(string nome, string valor, int exp, string path,string dominio, int secure);

onde:

nome - nome do cookie;

valor - valor armazenado no cookie;

exp - data de expirao do cookie (opcional), no formato Unix. Se no for definida, o cookie
ser de sesso;

path - path do script que gravou o cookie;

domnio - domnio responsvel pelo cookie;

secure - se tiver valor 1, indica que o cookie s pode ser transmitido por uma conexo segura
(https).

Observaes:

Um cookie no pode ser recuperado na mesma pgina que o gravou, a menos que esta seja
recarregada pelo browser;

Mltiplas chamadas funo setcookie sero executadas em ordem inversa;

Cookies s podem ser gravados antes do envio de qualquer informao para o cliente. Portanto
todas as chamadas funo setcookie devem ser feitas antes do envio de qualquer header ou
texto.


Apostila de PHP com MySQL

57
11.3. Lendo cookies gravados

Os cookies lidos por um script PHP ficam armazenados em duas variveis:

No array $HTTP_COOKIE_VARS[], tendo como ndice a string do nome do cookie;

E numa varivel cujo nome o mesmo do cookie, precedido pelo smbolo $.

Exemplo:

Um cookie que foi gravado numa pgina anterior pelo seguinte comando:

setcookie(teste, meu cookie);

Pode ser lida pela varivel $HTTP_COOKIE_VARS[teste] ou pela varivel $teste.

O script a seguir um exemplo do uso de cookies. O script exibe quantas vezes o usurio visitou aquela
pgina.

Arquivo cookie.php

<?

error_reporting(134);
/*
* Erro no script
* Nome do seu Script
* Por Seu nome ou nick
* e-mail = seumail@qualquercoisa.com.br
*/

?>

<?

if ($Test != '') {
$Test++;
setcookie("Test",$Test, time()+3600000); // selecionar o nome do cokie
} else {
setcookie("Test",1, time()+3600000); //Criar o valor 1
$Test = 1;
}
$numvisits = $Test;

?>

Esse o cdigo completo do arquivo cookie.php. Agora, digite o arquivo visitas.php que ir informar o
nmero de vezes que o site foi visitado por um mesmo usurio.

Arquivo visitas.php

<?
include("cookie.php");

echo "Voc j esteve aqui $numvisits vezes";
?>

Agora, vamos estudar o cdigo do arquivo cookie.php separadamente, para voc entend-lo melhor.

Apostila de PHP com MySQL

58

Logo aps as informaes pessoais e o reporting, podemos ver que temos o cdigo:


<?
if ($Test != ) {
$Test++;
setcookie("Test",$Test, time()+3600000);
}
?>

Essa parte ser a responsvel pela criao do cookie no computador cliente (do usurio). O comando else
que vem logo aps o o cdigo acima, usado para acionar o outro cdigo caso o cookie j exista no cliente.

Seguindo abaixo temos a fase terminal do script que respondera caso o cookie j exista, retornando o
nmero de vezes que o usurio j esteve no site.


<?
// ...
} else {
setcookie("Test",1, time()+3600000);
$Test = 1;
}
$numvisits = $Test;
?>

Esse cdigo aps verificar o cookie ir responder quantas vezes o cliente j esteve no site e ambas as
partes completaro a funo de gravar novamente os novos dados no cookie.

V para o seu browser, carregue a pgina visitas.php e observe que o browser lhe informar o nmero de
visitas que voc fez no site.

Outro exemplo de uso de cookies:

<?
setcookie("cookie", "teste", time() + 3600*24*365);
?>

Esse cookie tem validade de um ano:

3600 segundos = 1 hora
3600 segundos vezes 24 horas
24 horas vezes 365 dias

Para excluir um cookie basta fazer a mesmo sistema que criar ele, mas usando um prazo de expirao
negativa. Veja o exemplo a seguir:

<?
setcookie("cookie", "teste", time() 3600*24*365);
?>

Veja acima o cookie que tinha validade de um ano ser excludo pq foi passado que o tempo dele agora
de um ano atrs, ou seja, j acabou.


Apostila de PHP com MySQL

59
13. Trabalhando com Sesses (Sessions)


Uma sesso (session) um perodo de tempo durante o qual uma pessoa navega num site. Uma sesso
gravada no servidor, e o tempo de durao de uma sesso pode ser ate o usurio fechar a pgina. Quando
o usurio entra no site criamos uma sesso e ela recebe um nmero identificador nico, chamado de
session_id, para uma pagina ter o acesso aos dados da sesso ela tem que ter esse nmero identificador.

As sesses geralmente so usadas pra criar lojas virtuais e sistemas de login, onde o usurio entrar com
usurio e senha em um formulrio. Buscar no banco de dados e se achar algum usurio gravar na sesso
uma identificao que dir que ele j foi logado. Isso somente durar at o fechamento do browser.

Session_start() o comando para se utilizar uma sesso. Este comando deve ser utilizado no incio do
cdigo e antes de qualquer sada html.

Sintaxe:

Session_start();

Exemplo:

<?
session_start();
$_SESSION["teste"] = 1;
?>

No exemplo acima, foi criado uma sesso com o nome se teste e valor 1. E nas paginas seguintes voc
pode restaurar esse valor assim:

<?
session_start();
echo $_SESSION["teste"];
?>


13.1. Funo Session_register()

Voc pode usar session_register() para registrar suas variveis, no caso, o nome da varivel na sesso
ser a mesma do nome da varivel gravado, exemplo:

Exemplo:

<?
$linguagem = "PHP";
session_register("linguagem");
?>

Nesse caso foi gravada a varivel $linguagem na varivel de sesso linguagem, eis a vantagem de se
usar $_SESSION que recomendado a partir da verso 4.1, j que voc poder definir o nome da varivel
na sesso.

Obs.: session_register trabalha com register_globals on, e como est em extino o uso em on,
sempre recomendado ento usar $_SESSION, alis, as facilidades so muito maiores, j que voc
trabalhar com elas como uma varivel normal.



Apostila de PHP com MySQL

60
14. Funes do PHP


Neste captulo iremos listar algumas das funes utilizadas pelo PHP. Procuramos citar as funes que
verificamos serem comumente usadas por desenvolvedores de PHP. Para maiores informaes sobre as
funes aqui citadas e sobre as demais funes, consulte o manual do PHP no site: www.php.net.


14.1. Funes diversas


Funo chr( )

Esta funo retorna o caracter correspondente ao cdigo ASCII fornecido.

Sintaxe:

string chr(int ascii);

Exemplo:

<?
$texto = 65;
$ascii = chr($texto);
echo "O caracter correspondente ao cdigo ".$texto." da Tabela ASCII : "."<b>$ascii</b>";
?>


Funo ord( ) - Esta funo retorna o cdigo ASCII correspondente ao caracter fornecido.

Sintaxe:

int ord(string string);

Exemplo:

<?
$texto = 65;
$ord = ord($texto);
echo "O cdigo da tabela ASCII correspondente ao caracter ".$texto." : "."<b>$ord</b>";
?>


Funo strlen( ) - Esta funo retorna o tamanho da string fornecida.

Sintaxe:

int strlen(string str);

Exemplo:

<?
$texto = Curso de PHP";
$retorno = strlen($texto);
echo "Contedo de $texto: .$texto<p>;
echo Quantidade de caracteres: "."<b>$retorno</b>";
?>

Funo strtolower( ) - Esta funo retorna a string fornecida com todas as letras minsculas.

Apostila de PHP com MySQL

61

Sintaxe:

strtolower(string str);

Exemplo:

<?
$texto = CURSO DE PHP"; // Digite o texto em letras maisculas.
$retorno = strtolower($texto);
echo "Contedo de $texto: .$texto<p>;
echo Retorno da funo: "."<b>$retorno</b>";
?>


Funo strtoupper( ) - Esta funo retorna a string fornecida com todas as letras maisculas.

Sintaxe:

string strtoupper(string str);

Exemplo:

<?
$texto = curso de php"; // Digite o texto em letras minsculas.
$retorno = strtoupper($texto);
echo "Contedo de $texto: .$texto<p>;
echo Retorno da funo: "."<b>$retorno</b>";
?>


Funo ucfirst( ) - Esta funo retorna a string fornecida com o primeiro caracter em letra maiscula.

Sintaxe:

string ucfirst(string str);

Exemplo:

<?
$texto = curso de php"; // Digite o texto em letras minsculas.
$retorno = ucfirst($texto);
echo "Contedo de $texto: .$texto<p>;
echo Retorno da funo: "."<b>$retorno</b>";
?>


Funo ucwords( ) - Esta funo retorna a string fornecida com todas as palavras iniciadas por letras
maisculas.

Sintaxe:

string ucwords(string str);

Exemplo:

<?
$texto = curso de php"; // Digite o texto em letras minsculas.
$retorno = ucwords($texto);
echo "Contedo de $texto: .$texto<p>;
echo Retorno da funo: "."<b>$retorno</b>";
?>

Funo trim( ) - Esta funo retira espaos e linhas em branco do incio e do final da string fornecida.


Apostila de PHP com MySQL

62
Sintaxe:

string trim(string str);

Exemplo:

<?
$texto = curso 01 ;
$retorno = trim($texto);
echo Retorno da funo: "."<b>$retorno</b>";
?>

Funo strstr( ) - Esta funo procura a primeira ocorrncia de str2 em str1. Se no encontrar, retorna
uma string vazia, e se encontrar retorna todos os caracteres de str1 a partir desse ponto.

Sintaxe:

string strstr(string str1, string str2);

Exemplo:

<?
texto = Primeiro Curso de PHP;
$retorno = strstr($texto, Curso);
echo "Contedo de $texto: .$texto<p>;
echo Retorno da funo: "."<b>$retorno</b>";
?>

Funo isset( ) - Esta funo utilizada para verificar se uma varivel possui algum valor setado. Retorna
true se a varivel estiver setada (ainda que com uma string vazia ou o valor zero), e false em caso
contrrio.

Sintaxe:

int isset(mixed var);

Exemplo:

<?
$texto = curso;
$isset = isset($texto);
echo "valor do isset: ".$isset;
?>

Funo empty( ) - Esta funo verifica se uma varivel est vazia ou se contem o valor 0 (zero). Caso
esteja vazia, retorna o valor true(1), caso contrrio, retorna o valor false(0).

Sintaxe:

int empty(mixed var);

Exemplo:

<?
$texto = 0;
$empty = empty($texto);
echo "valor do isset: ".$isset;
?>

Funo date( ) - Esta funo retorna a data ou hora atual do sistema.

Sintaxe:

Apostila de PHP com MySQL

63

date(formato da data);

Exemplo:

<?
$data = date(d/m/y);
echo a data : $data;
?>

A funo date possui vrios argumentos que sero utilizados de acordo com a forma como a data ou hora
aparecer para o usurio. Veja os exemplos no script a seguir.

Exemplo 2:

<?
$dia = date('d');
$mes = date('m');
$ano2 = date('y');
$ano4 = date('Y');
$sem = date('w');
$data = date('d/m/Y');
$data1 = date('d/m/y');
$hora = date('h:m:s');
$h = date('h');
$min = date("m");

echo "
Data atual exibindo o ano com 4 dgitos: <b>$data</b> e com 2 dgitos: <b>$data1.</b><p>
\$dia = date('d')- exibe somente o dia da data atual do sistema. O dia : <b>$dia</b><p>
\$mes = date('m')- exibe somente o ms da data atual do sistema. O ms :
<b>$mes</b>$m<p>
\$ano2 = date('y')- exibe somente o ano com 2 dgitos da data atual do sistema. O ano :
<b>$ano2</b><p>
\$ano4 = date('Y')- exibe somente o ano com 4 dgitos da data atual do sistema. O ano :
<b>$ano4</b><p>
\$sem = date('s')- exibe o nmero correspondente ao dia da semana, de 0(domingo) a
7(sbado). O nmero : <b>$sem</b><p>
\$hora = date('h:m:s') - exibe a hora atual do sistema. A hora : <b>$hora</b><p>
\$h = date('h') - exibe somente o valor correspondente a hora do sistema. O valor da hora :
<b>$h</b><p>
\$min = date('m') - exibe somente o valor correspondente aos minuntos da hora do sistema.
O valor dos minutos : <b>$min</b><p>
";
?>

Funo explode( ) - Esta funo retorna um array contendo partes da string fornecida separadas pelo
padro fornecido, sem limitar o nmero de elementos do array.

Sintaxe:

Apostila de PHP com MySQL

64

array explode(string padrao, string str);

Exemplo:

<?
$data = 11/12/1975;
$data_array = explode(/,$data);
$novadata = $xdata_array[2]."-".$xdata[1]."-".$xdata[0];
echo $novadata;
?>

O cdigo acima faz com que a varivel $data_array receba o valor: array(11,12,1975);

O PHP ir exibir a data no seguinte formato:

Ano-mes-dia, ficando:

1975-12-11, pis o MySQL armazena as datas nesse formato.


Funo nl2br( ) - Esta funo retorna a string fornecida substituindo todas as quebras de linha (\n) por
quebras de linhas em html (<br>).

A funo acima pode ser utilizada, por exemplo, em um campo de comentrio em um formulrio.

Sintaxe:

string nl2br(string str);

Exemplo:

<?
$data = date("d/m/y");
echo nl2br("Curso de PHP\n Data de incio: $data\n Valor: R$ 700,00\n");
?>

No exemplo acima, a funo nl2br ir retornar:

Curso de PHP
Data de incio: a data atual do seu sistema
Valor: R$ 700,00


Funo substr( ) Esta funo retorna uma parte de uma string.

Sintaxe:

string substr ( string string, int start [, int length])

Se start no for negativo, a string retornada iniciar na posio start em string, comeando em zero. Por
exemplo, na string 'abcdef', o caractere na posio 0 'a', o caractere na posio 2 'c', e assim em diante.

Exemplos:

Exemplo 1) Uso bsico de substr()

<?

Apostila de PHP com MySQL

65
$rest = substr("abcdef", 1); // retorna "bcdef"
$rest = substr("abcdef", 1, 3); // retorna "bcd"
$rest = substr("abcdef", 0, 4); // retorna "abcd"
$rest = substr("abcdef", 0, 8); // retorna "abcdef"

// Outra opo acessar atravs de chaves

$string = 'abcdef';
echo $string{0}; // retorna a
echo $string{3}; // retorna d
?>

Se start for negativo, a string retornada ir comear no caractere start a partir do fim de string.

Exemplo 2) Usando um inicio negativo

<?
$rest = substr("abcdef", -1); // retorna "f"
$rest = substr("abcdef", -2); // retorna "ef"
$rest = substr("abcdef", -3, 1); // retorna "d"
?>

Se length for dado e for positivo, a string retornada ir conter length caracteres comeando em start
(dependendo do tamanho de string). Se a string menor do que start, ser retornado FALSE.

Se length for dado e for negativo, ento esta quantidade de caracteres ser omitida do final de string (aps
a posio de inicio ter sido calculada quando start for negativo).

Se start denota uma posio alm da truncagem, uma string vazia ser retornada.

Exemplo 3) Usando um length negativo

<?
$rest = substr("abcdef", 0, -1); // retorna "abcde"
$rest = substr("abcdef", 2, -1); // retorna "cde"
$rest = substr("abcdef", 4, -4); // retorna ""
$rest = substr("abcdef", -3, -1); // retorna "de"
?>


Apostila de PHP com MySQL

66
14.2. Funes de manipulao de arquivos


Funo File_exists( ) - Esta funo checa se um arquivo ou diretrio existe no servidor.

Sintaxe:

bool file_exists ( string nomedoarquivo)

Esta funo retorna TRUE se o arquivo ou diretrio especificado por nomedoarquivo existir; FALSE caso
contrrio.

Obs.: No Windows, para checar arquivos em compartilhamentos de rede, use:

//computername/share/filename; ou

\\\\computername\share\filename

Exemplo:

<?
$filename = '/caminho/para/qualquer.txt';

if (file_exists($filename)) {
print "O arquivo $filename existe";
} else {
print "O arquivo $filename no existe";
}
?>

Obs.: O resultado desta funo cacheada. Veja clearstatcache() para mais detalhes.

Esta funo no trabalha com arquivos remotos, de forma que o arquivo a ser examinado precisa ser
acessvel pelo sistema de arquivos do servidor.


Funo filesize( ) - Esta funo utilizada para ler o tamanho do arquivo. Retorna o tamanho do arquivo,
ou FALSE em caso de erro.

Sintaxe:

int filesize ( string nomedoarquivo)

Obs1.: O resultado desta funo cacheado. Veja clearstatcache() para mais detalhes.

Esta funo no trabalha com arquivos remotos, de forma que o arquivo a ser examinado precisa ser
acessvel pelo sistema de arquivos do servidor.

Exemplo:

<?
// Exibe algo como: arquivo.txt: 1024 bytes
$filename = 'arquivo.txt';
echo $filename . ': ' . filesize($filename) . ' bytes';
?>


Funo filetype( ) - Esta funo utilizada para ler o tipo de arquivo.

Apostila de PHP com MySQL

67

muito utilizada quando se deseja fazer uploads de arquivos e voc precisa verificar se o tipo de arquivo
que est sendo enviado est de acordo com os tipos permitidos por voc. Arquivos do tipo .exe, .ini, .bat,
normalmente so arquivos executveis e que podem conter vrus. Por isso, na maioria dos casos, no so
permitidos que sejam enviados para o servidor.

Esta funo retorna o tipo do arquivo (file type). Os valores possveis so fifo, char, dir, block, link, file e
unknown (desconhecido). Retorna FALSE se um erro ocorrer. Esta funo filetype() tambm produzir um
erro E_NOTICE se a chamada a stat falhar ou se o tipo de arquivo for desconhecido.

Sintaxe:

string filetype ( string nomedoarquivo)

Obs.: O resultado desta funo cacheado. Veja clearstatcache() para mais detalhes.

Esta funo no trabalha com arquivos remotos, de forma que o arquivo a ser examinado precisa ser
acessvel pelo sistema de arquivos do servidor.

Exemplo:

<?
echo filetype('/etc/passwd'); // file
echo filetype('/etc/'); // dir
?>


Funo: clearstatcache( ) - Esta funo utilizada para limpar as informaes em cache de arquivos que
foram verificados, por exemplo, pela funo filesize().

Sintaxe:

void clearstatcache ( void )

Quando voc chama stat(), lstat() ou qualquer uma das funes afetadas (listadas abaixo), o PHP mantm
em cache as informaes que essas funes retornam para melhoria de performance. Entretanto, em certos
casos voc pode precisar limpar as informaes cacheadas. Por exemplo, se um mesmo arquivo
verificado vrias vezes em um nico script, e esse arquivo corre o risco de ser apagado ou modificado
durante a operao do script, voc precisa limpar os dados do cache. Nesses casos, voc pode utilizar a
funo clearstatcache() para limpar todas as informaes que o PHP mantm sobre um arquivo.

As funes afetadas so stat(), lstat(), file_exists(), is_writable(), is_readable(), is_executable(), is_file(),
is_dir(), is_link(), filectime(), fileatime(), filemtime(), fileinode(), filegroup(), fileowner(), filesize(), filetype(), e
fileperms().

Obs.: Esta funo guarda informaes sobre arquivos especficos, de forma que voc somente
precisa chamar clearstatcache() se voc estiver realizando vrias operaes sobre o mesmo arquivo
e necessita que a informao sobre esse arquivo em particular no seja cacheada.

Exemplo:

<?
echo filetype('/etc/passwd'); // file
echo filetype('/etc/'); // dir
clearstatcache(); // neste momento esta funo limpou as informaes do cach do arquivo.
?>

Você também pode gostar