Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 03.06.2013
Сообщений: 17

2 таблицы в одном базе данных не могу создать

31.01.2014, 20:42. Показов 2630. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет
месяц назад не имел даже представления что такое БД но все получилось много читал и старался спасибо всем кто помогал теперь передомной стоит задача в одном БД сделать 2 таблицы здесь же в форуме есть отличный пример и ответ на мой вопрос Создать несколько таблиц в базе данных я постарался по примеру сделать но не получилось
так вот в моем БД есть таблица TABLE_GOODS я сохраняю 4 пункта в нем и даже могу видеть в listveiw
в нем я сохраняю приход
теперь мне надо создать таблицу TABLE_SELL где я буду сохранять что продал или отдал в долг
здесь я и остановился
пожалуйста подскажите мои ошибки и как их исправит сильно не пинайте
честно говоря я первый раз код пищу там показывает С# не обращайте внимание я не смог найти как будет Java показываться

Код Code
1
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
public class Goods {
    private int id;
    private String name_goods;
    private String date;
    private String amount;
    private String cost;
 
    public Goods() {
    }
 
    public Goods(int id, String name_goods, String date, String amount, String cost) {
        this.id = id;
        this.name_goods = name_goods;
        this.date = date;
        this.amount = amount;
        this.cost = cost;
    }
 
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    public String getName_goods() {
        return name_goods;
    }
 
    public void setName_goods(String name_goods) {
        this.name_goods = name_goods;
    }
 
    public String getDate() {
        return date;
    }
 
    public void setDate(String date) {
        this.date = date;
    }
 
    public String getAmount() {
        return amount;
    }
 
    public void setAmount(String amount) {
        this.amount = amount;
    }
 
    public String getCost() {
        return cost;
    }
 
    public void setCost(String cost) {
        this.cost = cost;
    }
 
    @Override
    public String toString() {
        return "Goods[id: " + id + ", name_goods: " + name_goods + ", date: " + date + ", " +
                "amount: " + amount + ", cost: " + cost + "]";
    }
 
}
здесь создаю БД

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
public class DBHandlerImpl extends SQLiteOpenHelper implements DBHandler<Goods>{
 
    private static final int DATABASE_VERSION = 3;
    private static final String DATABASE_NAME = "app_base";
 
    private static final String TABLE_GOODS = "users";
    private static final String TABLE_SELL = "sell";
    private static final String KEY_ID = "id";
    private static final String KEY_NAME_GOODS = "name_goods";
    private static final String KEY_DATE = "date";
    private static final String KEY_AMOUNT = "amount";
    private static final String KEY_COST = "cost";
 
    public DBHandlerImpl(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }
 
    @Override
    public void onCreate(SQLiteDatabase db) {
        String query = "Create Table " + TABLE_GOODS + "(" + KEY_ID + "INTEGER PRIMARY KEY, " +
                                                            KEY_NAME_GOODS + " TEXT, " +
                                                            KEY_DATE + " TEXT, " +
                                                            KEY_AMOUNT + " TEXT, " +
                                                            KEY_COST + " TEXT)";
        db.execSQL(query);
 
        String queryLose = "Create Table " + TABLE_SELL + "(" + KEY_ID + "INTEGER PRIMARY KEY, " +
                                                            KEY_NAME_GOODS + " TEXT, " +
                                                            KEY_DATE + " TEXT, " +
                                                            KEY_AMOUNT + " TEXT, " +
                                                            KEY_COST + " TEXT)";
        db.execSQL(queryLose);
 
    }
 
    @Override
    public void onUpgrade(SQLiteDatabase db, int i, int i2) {
 
    }
 
    @Override
    public void add(Goods goods) {
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
 
        values.put(KEY_NAME_GOODS, goods.getName_goods());
        values.put(KEY_DATE, goods.getDate());
        values.put(KEY_AMOUNT, goods.getAmount());
        values.put(KEY_COST, goods.getCost());
        db.insert(TABLE_GOODS, null, values);
 
        values.put(KEY_NAME_GOODS, goods.getName_goods());
        values.put(KEY_DATE, goods.getDate());
        values.put(KEY_AMOUNT, goods.getAmount());
        values.put(KEY_COST, goods.getCost());
        db.insert(TABLE_SELL, null, values);
 
        db.close();
    }
здесь работаю на Prihod Activity

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
public class Prihod extends Activity{
    private DBHandler<Goods> db;
    private Goods goods;
    private EditText edtTovar;
    private EditText editDate;
    private EditText editAmount;
    private EditText editCost;
    private Button btn_save;
    private Button btn_info;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.prihod);
        TextView textTovar = (TextView)findViewById(R.id.textTovar);
        TextView textDate = (TextView)findViewById(R.id.textDate);
        TextView textAmount = (TextView)findViewById(R.id.textAmount);
        TextView textCost = (TextView)findViewById(R.id.textCost);
        edtTovar = (EditText)findViewById(R.id.edtTovar);
        editDate = (EditText)findViewById(R.id.editDate);
        editAmount = (EditText)findViewById(R.id.editAmount);
        editCost = (EditText)findViewById(R.id.editCost);
        btn_save = (Button)findViewById(R.id.btn_save);
        btn_info = (Button)findViewById(R.id.btn_info);
        db = new DBHandlerImpl(this);
 
    }
 
    public void saveTovar(View v){
        AlertDialog.Builder builder = new AlertDialog.Builder(Prihod.this);
        builder.setTitle("Подтвердить сохранение...");
        builder.setMessage("Вы уверены, что хотите сохранить?");
        builder.setIcon(R.drawable.save);
        builder.setPositiveButton("Да", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                goods = new Goods(1, edtTovar.getText().toString(),
                        editDate.getText().toString(),
                        editAmount.getText().toString(),
                        editCost.getText().toString());
                db.add(goods);
                Toast.makeText(getApplicationContext(), "Новый товар сохранен!", Toast.LENGTH_SHORT).show();
            }
        });
 
        builder.setNegativeButton("Нет", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                dialog.cancel();
            }
        });
 
        builder.show();
    }
здесь Rashod Activity здесь я должен сохранять что продал или отдал в долг

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
public class Rashod extends Activity{
    private DBHandler<Goods> db;
    private Goods goods;
    private EditText editRashod;
    private EditText editDateRashod;
    private EditText editAmountRashod;
    private EditText editCostRashod;
    private Button btn_rashod_save;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.rashod);
        TextView textTovar = (TextView)findViewById(R.id.textTovar);
        TextView textDate = (TextView)findViewById(R.id.textDate);
        TextView textAmount = (TextView)findViewById(R.id.textAmount);
        TextView textCost = (TextView)findViewById(R.id.textCost);
        editRashod = (EditText)findViewById(R.id.edtTovar);
        editDateRashod = (EditText)findViewById(R.id.editDate);
        editAmountRashod = (EditText)findViewById(R.id.editAmount);
        editCostRashod = (EditText)findViewById(R.id.editCost);
        btn_rashod_save = (Button)findViewById(R.id.btn_rashod_save);
        db = new DBHandlerImpl(this);
    }
 
    public void saveRashod(View v){
        AlertDialog.Builder builder = new AlertDialog.Builder(Rashod.this);
        builder.setTitle("Подтвердить сохранение...");
        builder.setMessage("Вы уверены, что хотите сохранить?");
        builder.setIcon(R.drawable.save);
        builder.setPositiveButton("Да", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                goods = new Goods(1, editRashod.getText().toString(),
                        editDateRashod.getText().toString(),
                        editAmountRashod.getText().toString(),
                        editCostRashod.getText().toString());
                db.add(goods);
                Toast.makeText(getApplicationContext(), "Новый товар сохранен!", Toast.LENGTH_SHORT).show();
            }
        });
 
        builder.setNegativeButton("Нет", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                dialog.cancel();
            }
        });
 
        builder.show();
    }
}
Так вот пожалуйста здесь я какие ошибки делаю или правильно все
должен ли я другие имена дат им или так пойдут KEY_NAME_GOODS, KEY_DATE, KEY_AMOUNT, KEY_COST

C#
1
2
3
4
5
6
 String queryLose = "Create Table " + TABLE_SELL + "(" + KEY_ID + "INTEGER PRIMARY KEY, " +
                                                            KEY_NAME_GOODS + " TEXT, " +
                                                            KEY_DATE + " TEXT, " +
                                                            KEY_AMOUNT + " TEXT, " +
                                                            KEY_COST + " TEXT)";
        db.execSQL(queryLose);
Добавлено через 20 минут
забыл показать лог от сохранения таблиц
здесь таблица TABLE_GOODS

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
01-31 02:07:25.992  28544-28544/uz.akrampulatov.app E/SQLiteLog﹕ (1) no such table: sell
01-31 02:07:25.992  28544-28544/uz.akrampulatov.app E/SQLiteDatabase﹕ Error inserting amount=5 name_goods=nokia 1208 date=31.01.2014 cost=100
    android.database.sqlite.SQLiteException: no such table: sell (code 1): , while compiling: INSERT INTO sell(amount,name_goods,date,cost) VALUES (?,?,?,?)
            at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
            at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:882)
            at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:493)
            at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
            at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
            at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
            at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1467)
            at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1339)
            at uz.akrampulatov.app.activity.db.DBHandlerImpl.add(DBHandlerImpl.java:71)
            at uz.akrampulatov.app.activity.db.DBHandlerImpl.add(DBHandlerImpl.java:12)
            at uz.akrampulatov.app.activity.Prihod$1.onClick(Prihod.java:58)
            at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:4745)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
            at dalvik.system.NativeStart.main(Native Method)
здесь таблица TABLE_SELL

Code
1
2
3
4
5
6
7
8
9
10
11
12
01-31 02:09:48.836  28544-28544/uz.akrampulatov.app E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.NullPointerException
            at uz.akrampulatov.app.activity.Rashod$1.onClick(Rashod.java:48)
            at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:4745)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
            at dalvik.system.NativeStart.main(Native Method)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.01.2014, 20:42
Ответы с готовыми решениями:

Создать кнопку восстановления таблицы в базе данных Paradox
Я пишу программу телефонный справочник, мне надо создать кнопку восстановления. После изменении базы при щелчке на кнопку таблица база...

Подскажите,какие таблицы можно создать в этой базе данных
БД ”Видеотека” Состав атрибутов: • Название фильма; • Жанр; • Режиссер; • 3 наиболее известных фильма, снятых этим режиссером. ...

Не могу создать форму, удобную для ввода большого кол-ва данных в одном одной форме
Добрый день. Прошу помочь с организацией формы. (Большой, сложной таблтцы, но в одном окне) Вводная часть следующая: Есть таблица...

2
86 / 86 / 13
Регистрация: 03.03.2011
Сообщений: 1,873
01.02.2014, 00:09
http://developer.alexanderklim... tabase.php
0
Командир зеленых роботов
 Аватар для angryrobot
349 / 286 / 54
Регистрация: 08.10.2013
Сообщений: 576
01.02.2014, 15:05
Цитата Сообщение от Akramjon Посмотреть сообщение
пожалуйста подскажите мои ошибки
1) У вас неправильно формируется запрос на создание таблиц базы данных. Вы забыли пробел:

2) Поле id принято называть _id (это рекомендация, не более того)
3) id это ключевое поле, а это значит что каждая строка таблицы должна содержать уникальное значение для него. Насколько я понимаю, для добавления записей в таблицы, вы будете вызывать метод public void add(Goods goods). Видно что в этом методе вы заполнили все поля кроме id, это приведёт к ошибке. Обычно это поле делают автоматически увеличиваемым чтоб не мучиться с уникальностью значений, я рекомендую поступить так же. Для этого нужно немного переписать запрос который создает базу данных. Вместо
INTEGER PRIMARY KEY
напишите
INTEGER PRIMARY KEY AUTOINCREMENT
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.02.2014, 15:05
Помогаю со студенческими работами здесь

Люди как создать в базе данных отчёт определённого человека из таблицы, а не всех сразу!
Нужна помощь, есть задание, начал делать базу и столкнулся с проблемой как сделать ее именно под такое задание....вроде не сложно но не...

1) Создать Базу данных (Имя , Фамилия, Отчество) 2) Создать таблицу в Базе данных (состоящия из 3 столбцов(а,б,с) и 3 строк int) 3)Создать пользовате
Задача помогите незнаю ваще как даже сделать. Заранее спасибо большое: 1) Создать Базу данных (Имя , Фамилия, Отчество) 2) Создать...

сколько таблицы может быт сохранена в одном access базе?
сколько таблицы мы можем создать в одном access базе?

Неоднократной подключение к базе данных sql в одном обработчике
Всем доброго дня. У меня такая проблема. Есть база данных sql в ней несколько столбцов. Я подключаюсь к ней считываю информацию из одного...

Как объединять запросы к базе данных в одном файле, если их несколько штук?
Народ столкнулся с такое проблемой, у меня есть три запроса только они все в разных файлах но отвечают они за одну страницу, то-есть...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru