· 6 years ago · Jul 04, 2019, 10:34 PM
1public class Banco extends SQLiteOpenHelper {
2
3private static final String NOME_BANCO = "Bar.db";
4private static final int VERSAO_BANCO = 5;
5
6private static final String TIPO_TEXTO = " TEXT";
7private static final String TIPO_INTEIRO = " INTEGER";
8private static final String VIRGULA = ", ";
9
10private static final String SQL_CRIAR_TABELA_CATEGORIA =
11 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaCategoria.NOME_DA_TABELA + " (" +
12 Contrato.TabelaCategoria.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
13 Contrato.TabelaCategoria.COLUNA_NOME + TIPO_TEXTO +
14 ")";
15
16private static final String SQL_DELETAR_TABELA_CATEGORIA =
17 "DROP TABLE IF EXISTS " + Contrato.TabelaCategoria.NOME_DA_TABELA;
18
19private static final String SQL_CRIAR_TABELA_VENDEDOR =
20 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaVendedor.NOME_DA_TABELA + " (" +
21 Contrato.TabelaVendedor.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
22 Contrato.TabelaVendedor.COLUNA_NOME + TIPO_TEXTO + VIRGULA +
23 Contrato.TabelaVendedor.COLUNA_CPF + TIPO_TEXTO + VIRGULA +
24 Contrato.TabelaVendedor.COLUNA_NASCIMENTO + TIPO_TEXTO + VIRGULA +
25 Contrato.TabelaVendedor.COLUNA_TELEFONE + TIPO_TEXTO +
26 ")";
27
28private static final String SQL_DELETAR_TABELA_VENDEDOR =
29 "DROP TABLE IF EXISTS " + Contrato.TabelaVendedor.NOME_DA_TABELA;
30
31
32private static final String SQL_CRIAR_TABELA_PRODUTO =
33 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaProduto.NOME_DA_TABELA + " (" +
34 Contrato.TabelaProduto.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
35 Contrato.TabelaProduto.COLUNA_NOME + TIPO_TEXTO + VIRGULA +
36 Contrato.TabelaProduto.COLUNA_QUANTIDADE + TIPO_INTEIRO + VIRGULA +
37 Contrato.TabelaProduto.COLUNA_PRECO + TIPO_TEXTO + VIRGULA +
38 Contrato.TabelaProduto.COLUNA_CATEGORIA + TIPO_INTEIRO + VIRGULA +
39 "FOREIGN KEY ( " + Contrato.TabelaProduto.COLUNA_CATEGORIA + " ) REFERENCES " + Contrato.TabelaCategoria.NOME_DA_TABELA + " ( " + Contrato.TabelaCategoria.COLUNA_ID + " )" +
40 ")";
41
42private static final String SQL_DELETAR_TABELA_PRODUTO =
43 "DROP TABLE IF EXISTS " + Contrato.TabelaProduto.NOME_DA_TABELA;
44
45
46
47private static final String SQL_CRIAR_TABELA_PAGAMENTO =
48 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaPagamento.NOME_DA_TABELA + " (" +
49 Contrato.TabelaPagamento.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
50 Contrato.TabelaPagamento.COLUNA_NOME + TIPO_TEXTO +
51 ")";
52
53private static final String SQL_DELETAR_TABELA_PAGAMENTO =
54 "DROP TABLE IF EXISTS " + Contrato.TabelaPagamento.NOME_DA_TABELA;
55
56
57
58private static final String SQL_CRIAR_TABELA_ITEMPAGAMENTO =
59 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaItemPagamento.NOME_DA_TABELA + " (" +
60 Contrato.TabelaItemPagamento.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
61 Contrato.TabelaItemPagamento.COLUNA_VALOR + TIPO_TEXTO + VIRGULA +
62 Contrato.TabelaItemPagamento.COLUNA_PAGAMENTO + TIPO_INTEIRO + VIRGULA +
63 "FOREIGN KEY ( " + Contrato.TabelaItemPagamento.COLUNA_PAGAMENTO + " ) REFERENCES " + Contrato.TabelaPagamento.NOME_DA_TABELA + "( " + Contrato.TabelaPagamento.COLUNA_ID + " )" + VIRGULA +
64 Contrato.TabelaItemPagamento.COLUNA_VENDA + TIPO_INTEIRO + VIRGULA +
65 "FOREIGN KEY ( " + Contrato.TabelaItemPagamento.COLUNA_VENDA + " ) REFERENCES " + Contrato.TabelaVenda.NOME_DA_TABELA + "( " + Contrato.TabelaVenda.COLUNA_ID + " )" +
66 ")";
67
68private static final String SQL_DELETAR_TABELA_ITEMPAGAMENTO =
69 "DROP TABLE IF EXISTS " + Contrato.TabelaItemPagamento.NOME_DA_TABELA;
70
71
72
73private static final String SQL_CRIAR_TABELA_ITEMVENDA =
74 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaItemVenda.NOME_DA_TABELA + " (" +
75 Contrato.TabelaItemVenda.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
76 Contrato.TabelaItemVenda.COLUNA_PRECO + TIPO_TEXTO + VIRGULA +
77 Contrato.TabelaItemVenda.COLUNA_QUANTIDADE + TIPO_INTEIRO + VIRGULA +
78 Contrato.TabelaItemVenda.COLUNA_SUBTOTAL + TIPO_TEXTO + VIRGULA +
79 Contrato.TabelaItemVenda.COLUNA_PRODUTO + TIPO_INTEIRO + VIRGULA +
80 "FOREIGN KEY ( " + Contrato.TabelaItemVenda.COLUNA_PRODUTO + " ) REFERENCES " + Contrato.TabelaProduto.NOME_DA_TABELA + "( " + Contrato.TabelaProduto.COLUNA_ID + " )" + VIRGULA +
81 Contrato.TabelaItemVenda.COLUNA_VENDA + TIPO_INTEIRO + VIRGULA +
82 "FOREIGN KEY ( " + Contrato.TabelaItemVenda.COLUNA_VENDA + " ) REFERENCES " + Contrato.TabelaVenda.NOME_DA_TABELA + "( " + Contrato.TabelaVenda.COLUNA_ID + " )" +
83 " )";
84
85private static final String SQL_DELETAR_TABELA_ITEMVENDA =
86 "DROP TABLE IF EXISTS " + Contrato.TabelaItemVenda.NOME_DA_TABELA;
87
88
89
90private static final String SQL_CRIAR_TABELA_VENDA =
91 "CREATE TABLE IF NOT EXISTS " + Contrato.TabelaVenda.NOME_DA_TABELA + " (" +
92 Contrato.TabelaVenda.COLUNA_ID + TIPO_INTEIRO + " PRIMARY KEY AUTOINCREMENT" + VIRGULA +
93 Contrato.TabelaVenda.COLUNA_DATA + TIPO_TEXTO + VIRGULA +
94 Contrato.TabelaVenda.COLUNA_MESA + TIPO_INTEIRO + VIRGULA +
95 Contrato.TabelaVenda.COLUNA_STATUS + TIPO_INTEIRO + VIRGULA +Contrato.TabelaVenda.COLUNA_VENDEDOR + TIPO_INTEIRO + VIRGULA +
96 "FOREIGN KEY(" + Contrato.TabelaVenda.COLUNA_VENDEDOR + ") REFERENCES " + Contrato.TabelaVendedor.NOME_DA_TABELA + "(" + Contrato.TabelaVendedor.COLUNA_ID + ")" +
97 ")";
98
99private static final String SQL_DELETAR_TABELA_VENDA =
100 "DROP TABLE IF EXISTS " + Contrato.TabelaVenda.NOME_DA_TABELA;
101
102
103//Construtor
104public Banco(Context context) {
105 super(context, NOME_BANCO, null, VERSAO_BANCO);
106}
107
108
109
110
111@Override
112public void onCreate(SQLiteDatabase db) {
113 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_CATEGORIA);
114 db.execSQL(SQL_CRIAR_TABELA_CATEGORIA);
115
116 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_VENDEDOR);
117 db.execSQL(SQL_CRIAR_TABELA_VENDEDOR);
118
119 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_PRODUTO);
120 db.execSQL(SQL_CRIAR_TABELA_PRODUTO);
121
122 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_PAGAMENTO);
123 db.execSQL(SQL_CRIAR_TABELA_PAGAMENTO);
124
125 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_VENDA);
126 db.execSQL(SQL_CRIAR_TABELA_VENDA);
127
128 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_ITEMPAGAMENTO);
129 db.execSQL(SQL_CRIAR_TABELA_ITEMPAGAMENTO);
130
131 Log.v("CRIAR_BANCO", SQL_CRIAR_TABELA_ITEMVENDA);
132 db.execSQL(SQL_CRIAR_TABELA_ITEMVENDA);
133}
134
135V/CRIAR_BANCO: CREATE TABLE IF NOT EXISTS tb_Categorias (CategoriaId INTEGER PRIMARY KEY AUTOINCREMENT, CategoriaNome TEXT)
136CREATE TABLE IF NOT EXISTS tb_Vendedores (VendedorId INTEGER PRIMARY KEY AUTOINCREMENT, VendedorNome TEXT, VendedorCpf TEXT, VendedorDataDeNascimento TEXT, VendedorTelefone TEXT)
137CREATE TABLE IF NOT EXISTS tb_Produtos (ProdutoId INTEGER PRIMARY KEY AUTOINCREMENT, ProdutoNome TEXT, ProdutoQuantidade INTEGER, ProdutoPreço TEXT, CategoriaDoProduto INTEGER, FOREIGN KEY ( CategoriaDoProduto ) REFERENCES tb_Categorias ( CategoriaId ))
138CREATE TABLE IF NOT EXISTS tb_Pagamentos (PagamentoId INTEGER PRIMARY KEY AUTOINCREMENT, FormaDePagamento TEXT)
139CREATE TABLE IF NOT EXISTS tb_Vendas (VendasId INTEGER PRIMARY KEY AUTOINCREMENT, VendasData TEXT, VendasMesa INTEGER, VendasStatus INTEGER, VendasVendedor INTEGER, FOREIGN KEY(VendasVendedor) REFERENCES tb_Vendedores(VendedorId))
140CREATE TABLE IF NOT EXISTS tb_ItensPagamento (ItensPagamentoId INTEGER PRIMARY KEY AUTOINCREMENT, ItensPagamentoValor TEXT, ItensPagamentoPagamento INTEGER, FOREIGN KEY ( ItensPagamentoPagamento ) REFERENCES tb_Pagamentos( PagamentoId ), ItensPagamentoVenda INTEGER, FOREIGN KEY ( ItensPagamentoVenda ) REFERENCES tb_Vendas( VendasId ))
141E/SQLiteLog: (1) near "ItensPagamentoVenda": syntax error
142D/AndroidRuntime: Shutting down VM
143W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x9cc98b20)
144E/AndroidRuntime: FATAL EXCEPTION: main
145Process: com.example.ti.bar, PID: 4595
146java.lang.IllegalStateException: Could not execute method for android:onClick
147 at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:390)
148 at android.view.View.performClick(View.java:4438)
149 at android.view.View$PerformClick.run(View.java:18422)
150 at android.os.Handler.handleCallback(Handler.java:733)
151 at android.os.Handler.dispatchMessage(Handler.java:95)
152 at android.os.Looper.loop(Looper.java:136)
153 at android.app.ActivityThread.main(ActivityThread.java:5017)
154 at java.lang.reflect.Method.invokeNative(Native Method)
155 at java.lang.reflect.Method.invoke(Method.java:515)
156 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
157 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
158 at dalvik.system.NativeStart.main(Native Method)
159 Caused by: java.lang.reflect.InvocationTargetException
160 at java.lang.reflect.Method.invokeNative(Native Method)
161 at java.lang.reflect.Method.invoke(Method.java:515)
162 at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:385)
163 at android.view.View.performClick(View.java:4438)
164 at android.view.View$PerformClick.run(View.java:18422)
165 at android.os.Handler.handleCallback(Handler.java:733)
166 at android.os.Handler.dispatchMessage(Handler.java:95)
167 at android.os.Looper.loop(Looper.java:136)
168 at android.app.ActivityThread.main(ActivityThread.java:5017)
169 at java.lang.reflect.Method.invokeNative(Native Method)
170 at java.lang.reflect.Method.invoke(Method.java:515)
171 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
172 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
173 at dalvik.system.NativeStart.main(Native Method)
174 Caused by: android.database.sqlite.SQLiteException: near "ItensPagamentoVenda": syntax error (code 1): , while compiling: CREATE TABLE IF NOT EXISTS tb_ItensPagamento (ItensPagamentoId INTEGER PRIMARY KEY AUTOINCREMENT, ItensPagamentoValor TEXT, ItensPagamentoPagamento INTEGER, FOREIGN KEY ( ItensPagamentoPagamento ) REFERENCES tb_Pagamentos( PagamentoId ), ItensPagamentoVenda INTEGER, FOREIGN KEY ( ItensPagamentoVenda ) REFERENCES tb_Vendas( VendasId ))
175 at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
176 at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:889)
177 at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:500)
178 at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
179 at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
180 at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
181 at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1672)
182 at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1603)
183 at com.example.ti.bar.dal.Banco.onCreate(Banco.java:151)
184 at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:252)
185 at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
186 at com.example.ti.bar.dal.Banco.cadastrarPagamento(Banco.java:633)
187 at com.example.ti.bar.dal.PagamentoDAO.cadastrarPagamento(PagamentoDAO.java:14)
188 at com.example.ti.bar.view.PagamentoActivity.btnCadastrarPagamento(PagamentoActivity.java:36)
189 at java.lang.reflect.Method.invokeNative(Native Method)
190 at java.lang.reflect.Method.invoke(Method.java:515)
191 at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:385)
192 at android.view.View.performClick(View.java:4438)
193 at android.view.View$PerformClick.run(View.java:18422)
194 at android.os.Handler.handleCallback(Handler.java:733)
195 at android.os.Handler.dispatchMessage(Handler.java:95)
196 at android.os.Looper.loop(Looper.java:136)
197 at android.app.ActivityThread.main(ActivityThread.java:5017)
198 at java.lang.reflect.Method.invokeNative(Native Method)
199 at java.lang.reflect.Method.invoke(Method.java:515)
200 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
201 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
202 at dalvik.system.NativeStart.main(Native Method)
203Application terminated.