sexta-feira, 5 de junho de 2009

PHP - Como inserir o resultado de uma consulta Mysql num array utilizando a função array_push

A seguir será demonstrado como conectar com banco de dados Mysql e realizar uma consulta.

Os dados obtidos serão inseridos num array contendo a chave e o valor de cada elemento. A chave é nome do campo da tabela, o valor é o conteúdo do campo.



/** Conexão **/
mysql_connect("localhost", "root","") or
die("Não foi possível conectar: " . mysql_error()); // mensagem de excessão

mysql_select_db("testes"); // seta o banco de dados

$resultado = mysql_query("SELECT * FROM tb_usuario"); // consulta sql

$arrayDados = array(); // criar array vazio

while($linha = mysql_fetch_array($resultado, MYSQL_NUM)) {
// incluir valores no array
array_push($arrayDados,
array('id_usuario'=>$linha[0],
'no_usuario'=>$linha[1]
)
);
}

// conferir valores do array
foreach($arrayDados as $chave) {
echo var_dump($chave). "
";
}

// liberar memória utilizada para consulta
mysql_free_result($resultado);


fonte: php.net

Atenciosamente,
Rondson Lima

quarta-feira, 3 de junho de 2009

PHP - Como criar um array com quantidade de chaves e valores pré-determinados

A função array_fill do PHP possibilita a criação de um array com chaves e valores determinados por parâmetro. Exemplo:

$valoresMes = array_fill(1,31,0);

O primeiro parâmetro é passado o valor inicial da chave.
O segundo parâmetro é passado o valor final da chave.
O terceiro parâmetro é passado o valor que cada elemento terá.

resultado:

Array
(
[1] => 0
[2] => 0
[3] => 0
[4] => 0
[n] => 0
[31] => 0
)


O exemplo acima poderá ser utilizado, na prática, para informar o número de ocorrências em dias de determinados meses.

fonte: php.net

Atenciosamente,
Rondson Lima.

segunda-feira, 1 de junho de 2009

PHP - Zend Framework - Tutorial - Como construir um formulário utilizando Zend_Form

Conforme os padrões de arquitetura do Zend Framework, devemos considerar a estrutura de pastas conforme abaixo:


A classe UsuarioController deverá possuir o conteúdo a seguir:

UsuarioController.php


class UsuarioController extends GenericoController {

public function getForm() {

$form = new Zend_Form();

$form->setAction($this->getBaseUrl().'/usuario/login')
->setMethod('post');

// cria e configura o elemento usuário
$usuario = $form->createElement('text', 'usuario');
$usuario->addValidator('alnum')
->addValidator('regex', false, array('/^[a-z]/i'))
->addValidator('stringLength', false, array(6,20))
->setRequired(true)
->addFilter('StringToLower');

// cria e configura o elemento senha
$senha = $form->createElement('password', 'senha');
$senha->addValidator('StringLength', false, array(6))
->setRequired(true);

// adiciona elementos ao formulário
$form->addElement($usuario)
->addElement($senha)
->addElement('submit', 'login', array('label' => 'Login'));

return $form;
}

public function indexAction() {
// renderize usuario/form.phtml
$this->view->form = $this->getForm();
$this->render('form');
}

public function loginAction() {
if(!$this->getRequest()->isPost()) {
return $this->_forward('index');
}

$form = $this->getForm();

if(!$form->isValid($_POST)) {
//falha na validação; exibe o formulário novamente
$this->form = $form;
return $this->render('form');
}

$valor = $form->getValues();
}

}


Observação no $this->getBaseUrl(). Deverá ser inserida a baseUrl do projeto, inseri o método no GenericoController para ser utilizado nos demais Controllers, o método é público e contém o código return $this->getFrontController()->getBaseUrl();

O arquivo form.phtml deverá possuir o seguinte conteúdo: < ? = $this->form; ?>

Caso seja exibido apenas form; ?>, é necessário habilitar as short tags no PHP conforme exemplo a seguir:

Habilitar short tags no PHP

No arquivo configuração do PHP, php.ini procure pela palavra abaixo:

short_open_tag

Apague off e escreva on.
Reinicie o Apache.

Pronto, agora a tag estará disponível para utilização. Conforme rege a documentação oficial do Zend_Form.

fonte: http://framework.zend.com/manual/en/zend.form.html

Atenciosamente,
Rondson Lima