9
respostas

Banco de Dados não funcionando

Acabei de concluir a atividade quatro e após superar um probleminha que solucionei com ajuda do fórum, consegui fazer o programa compilar sem erros de sinaxe e funcionar perfeitamente no primeiro de 5 videos da aula 4. Porém ao final do terceiro, quarto e quinto videos (após a introdução dos conceitos de salvamento de banco de dados), o programa operou sem erros de sintaxe, executa normalmente porém não armazena no banco de dados sendo assim, embora a mensagem de aluno salvo aconteça, a lista permanece vazia (mesmo fechando e abrindo o programa tudo permanece o mesmo e mesmo após a ultima aula aonde se cria o metodo carrega lista e é aplicado ao onResume).

9 respostas

Oi Tales, tudo bem ?

Cara mostra para gente o código do seu dao e de suas duas activities para gente dar uma analisada ?

Mostro sim cara, eu avisei que ia ter mais problema.

Lista Alunos:

package com.tales.agenda;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;

import com.tales.agenda.DAO.AlunoDAO;
import com.tales.agenda.Model.Aluno;
import java.util.List;

public class ListaAlunosActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_lista_alunos);
        carregaLista();
        Button novoAluno = (Button) findViewById(R.id.lista_alunos_novoAluno);
        novoAluno.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intentVaiProFormulario = new Intent(ListaAlunosActivity.this, FormularioActivity.class);
                startActivity(intentVaiProFormulario);
            }
        });
    }
    private void carregaLista()  {
        AlunoDAO dao = new AlunoDAO(this);
        List<Aluno> alunos = dao.buscaAlunos(); dao.close();
        ListView listaAlunos = (ListView)  findViewById(R.id.lista_alunos_listaAlunos);
        ArrayAdapter<Aluno> adapter = new ArrayAdapter<Aluno>(this,  android.R.layout.simple_list_item_1, alunos);
        listaAlunos.setAdapter(adapter);
    }

    @Override
    protected void onResume() {
        super.onResume();
        carregaLista();
    }
}

Formulario Activity

package com.tales.agenda;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Toast;

import com.tales.agenda.DAO.AlunoDAO;
import com.tales.agenda.Model.Aluno;

public class FormularioActivity extends AppCompatActivity {

    private FormularioHelper helper;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_formulario);

        helper = new FormularioHelper(this);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater inflater = getMenuInflater();
        inflater.inflate(R.menu.menu_formulario, menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case R.id.menu_formulario_ok:
                Aluno aluno = helper.pegaAluno();
                AlunoDAO dao = new AlunoDAO(this);
                dao.insere(aluno);
                dao.close();

                Toast.makeText(FormularioActivity.this, "Aluno " + aluno.getNome() + " salvo!", Toast.LENGTH_SHORT).show();

                finish();
                break;
        }


        return super.onOptionsItemSelected(item);
    }
}

E aqui o Aluno DAO

package com.tales.agenda.DAO;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import com.tales.agenda.Model.Aluno;

import java.util.ArrayList;
import java.util.List;

public class AlunoDAO extends SQLiteOpenHelper {
    public AlunoDAO(Context context) {
        super(context, "Agenda", null, 1);
    }

    @Override
    public void onCreate (SQLiteDatabase db) {
        String sql = "CREATE TABLE Alunos (id INTEGER PRIMARY KEY, nome TEXT NOT NULL, endereço TEXT, telefone TEXT, site TEXT, nota REAL);";
        db.execSQL(sql);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        String sql = "DROP TABLE IF EXISTS Alunos";
        db.execSQL(sql);
        onCreate(db);
    }

    public void insere(Aluno aluno)  {
        SQLiteDatabase db = getWritableDatabase();

        ContentValues dados = new ContentValues();
        dados.put("nome", aluno.getNome());
        dados.put("endereco", aluno.getEndereco());
        dados.put("telefone", aluno.getTelefone());
        dados.put("site", aluno.getSite());
        dados.put("nota", aluno.getNota());

        db.insert("Alunos", null, dados );
    }


    public List<Aluno> buscaAlunos()  {
        String sql = "SELECT * FROM Alunos;";
        SQLiteDatabase db = getReadableDatabase();
        Cursor c = db.rawQuery(sql, null);

        List<Aluno> alunos = new ArrayList<Aluno>();
        while (c.moveToNext()) {
            Aluno aluno = new Aluno();
            aluno.setId(c.getLong(c.getColumnIndex("id")));
            aluno.setNome(c.getString(c.getColumnIndex("nome")));
            aluno.setEndereco(c.getString(c.getColumnIndex("endereco")));
            aluno.setTelefone(c.getString(c.getColumnIndex("telefone")));
            aluno.setSite(c.getString(c.getColumnIndex("site")));
            aluno.setNota(c.getDouble(c.getColumnIndex("nota")));

            alunos.add(aluno);

        }
        c.close();

        return alunos;

    }
}

Tales, acho que está dando problema na hora de inserir e buscar, na criação você chamou uma coluna de endereço e na inserção e busca chamou de endereco.

Ele não reconhece a coluna e quebra.

Não tinha notado isso, como eu já tinha feito a aula anteriormente, na correria eu fiz um Ctrl+C Ctrl+V direto da página da descrição do video no Alura aonde tem o código fonte. Corrigi esse problema do endereço e acabei de testar não resolveu, reiniciei o Android Studio, não resolveu, liguei o PC agora (no dia seguinte) testei, não funcionou ainda o banco.

Não tinha notado isso, como eu já tinha feito a aula anteriormente, na correria eu fiz um Ctrl+C Ctrl+V direto da página da descrição do video no Alura aonde tem o código fonte. Corrigi esse problema do endereço e acabei de testar não resolveu, reiniciei o Android Studio, não resolveu, liguei o PC agora (no dia seguinte) testei, não funcionou ainda o banco. Agora pela manhã, conclui todas as 5 aulas da parte 1 do Android com o AndroidStudio mas com o programa não funcionando. Baixei pelo link pro github o projeto do Android completo (este que veio com erros estranhos que não o deixaram compilar quando abri) e conferi linha a linha o projeto de vocês com o meu que (tirando alguns nomes de variáveis e métodos) agora está idêntico e não funcional do mesmo jeito. O arquivo roda, chama as telas, compila sem nenhum erro de sintaxe porém o arquivo não é salvo e a tela inicial permanece em branco sem nenhum item salvo.

Peço ajuda pra resolver esse erro pois estou empacado no mesmo a coisa de 1 semana e sem ele não posso prosseguir pra parte dois do projeto. Vale dizer que estou com a ultima versão do AndroidStudio com inclusive o Android P já baixado e instalado e todos os outros itens

Oi Tales,

Cara consegue desinstalar o aplicativo do celular/emulador e rodar novamente ?

Você fala criar outra maquina virtual?