Gravando e Lendo dados no Mysql com Python

Dando continuidade ao que comecei em Dos Sistemas em Access para o Linux e Python, MySQL e adeus, Access, vou mostrar para o Cléberson como ele pode conectar ao MySQL seu programa em Python.

Estou acreditando que o Cléberson já conseguiu instalar o MySQL, o Python e o python-mysqldb e já consegue executar alguma coisa em python.

python-mysqldb é um módulo para o python. Deve ser importado no seu programa com a linha abaixo:

import MySQLdb

Com o modulo importado, podemos então criar uma conexão:

conexao = MySQLdb.connect('endereço do servidor' , 'usuario do mysql' , 'senha')

É bom definir o banco de dados dentro do MySQL que você vai usar:

conexao.select_db('meubanco')

Simples assim. Três linhas e o Cléberson já tem uma conexão com o MySQL em Python. Na realidade a conexão mesmo depende só das duas primeiras linhas.

Pausa. Me adiantei demais.

Vamos criar um banco de verdade agora para podermos usá-lo com o Python.

Como o Cléberson já fez a lição de casa e já sabe usar algum cliente do MySQL, ele só precisa dar 2 comandinhos no cliente MySQL que ele prefere:

create database teste;

create table teste.pessoas (nome varchar(60), idade int);

Pronto. Está criado o banco teste, que contém a tabela pessoas. A tabela pessoas tem dois campos: nome e idade. O campo nome aceita strings (texto) com até 60 caracteres. O campo idade aceita números inteiros.

Ao Python, finalmente. Faremos dois programas: uma para gravar dados na tabela pessoas, outro para exibir estes dados no terminal. Cléberson, eu peço que tenhas paciência. Nosso programa não vai ter janelas ainda. Vai rodar no terminal.

Código do primeiro programa:

# importar o modulo para 'falar' com o MySQL
import MySQLdb

def gravarPessoa(cursor,nome, idade):
    sql="insert into pessoas values( '" + nome + "'," + idade + " ) "
    try:
        cursor.execute(sql)
    except MySQLdb.Warning, w:
        print w
    except MySQLdb.Error, e:
        print "Erro executando \n " + sql
        print e

# criando uma conexao mysql
# com o servidor na mesma maquina( localhost )
# usuario root do mysql
# e senha em branco
conexao=MySQLdb.connect( 'localhost' , 'root' , '' )

# selecionando o banco 'teste'
conexao.select_db( 'teste' )

#criando um 'cursor'
cursor=conexao.cursor()

sair=None
while sair<> 'S' :
    nome=raw_input( 'Digite o nome: ' )
    idade = raw_input('Digite a idade: ' )
    gravarPessoa( cursor , nome , idade )
    sair = raw_input( ' Digite S para sair ou tecle enter para continuar ' )

Agora salvaremos este arquivo como gravadados.py e no terminal exacutamos com python gravadados.py

O próximo artigo vai só mostrar como exibir os dados do MySQL.

Até lá.

Anúncios

3 Respostas to “Gravando e Lendo dados no Mysql com Python”

  1. Prezado Sr.

    Estou mudando minhas bases de dados de MA Access para MySQL. Para fazer minhas consultas estou começando com o Python.
    Estou dsenvolvendo consultas via Python, mas os resultados só me aparecem na tela. Estou tentando:
    1. Fazer com que a impressão na rela seja controlada, pois os BD são grandes.
    2. Imprimir em papel as consultas solicitadas.

    Já procurei em vários tutoriais, e não consigo encontrar uma solução para essa dificuldade.

    Contando com sua compreensão,

    Paulo

  2. “Cléberson, eu peço que tenhas paciência. Nosso programa não vai ter janelas ainda. Vai rodar no terminal.”

    Cara to doido pra ver a continuação dessa saga rs. Muito bom o blog, não faz ideia de como vai me ajudar a aprender Python! Ja ta no favoritos aqui ! Abraços e muita saude pra vc!

  3. meu deus vc ja deu continuidade nesse post eu quero mt saber
    como faz p aparecer os dados do banco na janela gtk ou se tem como fazer tipo um relatorio..

Deixe um comentário

Preencha os seus dados abaixo ou clique em um ícone para log in:

Logotipo do WordPress.com

Você está comentando utilizando sua conta WordPress.com. Sair / Alterar )

Imagem do Twitter

Você está comentando utilizando sua conta Twitter. Sair / Alterar )

Foto do Facebook

Você está comentando utilizando sua conta Facebook. Sair / Alterar )

Foto do Google+

Você está comentando utilizando sua conta Google+. Sair / Alterar )

Conectando a %s

%d blogueiros gostam disto: