Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
19 / 5 / 2
Регистрация: 28.09.2014
Сообщений: 88

Ошибка при создании SQLite

09.03.2015, 14:14. Показов 2276. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
При запуске приложения вылетает ошибка:
Кликните здесь для просмотра всего текста

03-09 11:04:42.436 1556-1556/ru.scratty.myrec E/SQLiteLog﹕ (1) table "records" has more than one primary key
03-09 11:04:42.436 1556-1556/ru.scratty.myrec D/AndroidRuntime﹕ Shutting down VM
03-09 11:04:42.448 1556-1556/ru.scratty.myrec W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0xa4d82b20)
03-09 11:04:42.452 1556-1556/ru.scratty.myrec E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: ru.scratty.myrec, PID: 1556
java.lang.RuntimeException: Unable to start activity ComponentInfo{ru.scratty.myrec/ru.scratty.myrec.BrowsingActivity}: android.database.sqlite.SQLiteException: table "records" has more than one primary key (code 1): , while compiling: CREATE TABLE records(id INTEGER PRIMARY KEY, head TEXT, description TEXT, like INTEGER PRIMARY KEY)
at android.app.ActivityThread.performLaunch Activity(ActivityThread.java:2184)
at android.app.ActivityThread.handleLaunchA ctivity(ActivityThread.java:2233)
at android.app.ActivityThread.access$800(Ac tivityThread.java:135)
at android.app.ActivityThread$H.handleMessa ge(ActivityThread.java:1196)
at android.os.Handler.dispatchMessage(Handl er.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(Activity Thread.java:5001)
at java.lang.reflect.Method.invokeNative(Na tive Method)
at java.lang.reflect.Method.invoke(Method.j ava:515)
at com.android.internal.os.ZygoteInit$Metho dAndArgsCaller.run(ZygoteInit.java:785)
at com.android.internal.os.ZygoteInit.main( ZygoteInit.java:601)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.database.sqlite.SQLiteException: table "records" has more than one primary key (code 1): , while compiling: CREATE TABLE records(id INTEGER PRIMARY KEY, head TEXT, description TEXT, like INTEGER PRIMARY KEY)
at android.database.sqlite.SQLiteConnection .nativePrepareStatement(Native Method)
at android.database.sqlite.SQLiteConnection .acquirePreparedStatement(SQLiteConnecti on.java:889)
at android.database.sqlite.SQLiteConnection .prepare(SQLiteConnection.java:500)
at android.database.sqlite.SQLiteSession.pr epare(SQLiteSession.java:588)
at android.database.sqlite.SQLiteProgram.<i nit>(SQLiteProgram.java:58)
at android.database.sqlite.SQLiteStatement. <init>(SQLiteStatement.java:31)
at android.database.sqlite.SQLiteDatabase.e xecuteSql(SQLiteDatabase.java:1672)
at android.database.sqlite.SQLiteDatabase.e xecSQL(SQLiteDatabase.java:1603)
at ru.scratty.myrec.DBManager.onCreate(DBMa nager.java:33)
at android.database.sqlite.SQLiteOpenHelper .getDatabaseLocked(SQLiteOpenHelper.java :252)
at android.database.sqlite.SQLiteOpenHelper .getWritableDatabase(SQLiteOpenHelper.ja va:164)
at ru.scratty.myrec.DBManager.addItem(DBMan ager.java:44)
at ru.scratty.myrec.BrowsingActivity.onCrea te(BrowsingActivity.java:26)
at android.app.Activity.performCreate(Activ ity.java:5231)
at android.app.Instrumentation.callActivity OnCreate(Instrumentation.java:1087)
at android.app.ActivityThread.performLaunch Activity(ActivityThread.java:2148)
************at android.app.ActivityThread.handleLaunchA ctivity(ActivityThread.java:2233)
************at android.app.ActivityThread.access$800(Ac tivityThread.java:135)
************at android.app.ActivityThread$H.handleMessa ge(ActivityThread.java:1196)
************at android.os.Handler.dispatchMessage(Handl er.java:102)
************at android.os.Looper.loop(Looper.java:136)
************at android.app.ActivityThread.main(Activity Thread.java:5001)
************at java.lang.reflect.Method.invokeNative(Na tive Method)
************at java.lang.reflect.Method.invoke(Method.j ava:515)
************at com.android.internal.os.ZygoteInit$Metho dAndArgsCaller.run(ZygoteInit.java:785)
************at com.android.internal.os.ZygoteInit.main( ZygoteInit.java:601)
************at dalvik.system.NativeStart.main(Native Method)



Ошибок в коде вроде бы нету, но приложение работать отказывается. прошу помочь разобраться в проблеме. Вот классы, задействованные в процессе:

Java
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
public class Item {
 
    private int id;
    private String head;
    private String description;
    private int like;
 
    public Item(String head, String description, int like) {
        this.head = head;
        this.description = description;
        this.like = like;
    }
 
    public Item() {}
 
    public String getHead() {
        return head;
    }
 
    public String getDescription() {
        return description;
    }
 
    public int getLike() {
        return like;
    }
 
    public int getID() {
        return id;
    }
 
    public void setHead(String val) {
        head = val;
    }
 
    public void setDescription(String val) {
        description = val;
    }
 
    public void setLike(int val) {
        like = val;
    }
 
    public void setID(int val) {
        id = val;
    }
}
Java
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
 
import java.util.ArrayList;
 
public class DBManager extends SQLiteOpenHelper{
 
    private static final int DATABASE_VERSION = 1;
    private static final String DATABASE_NAME = "my_records";
    private static final String TABLE_NAME = "records";
 
    private static final String KEY_ID = "id";
    private static final String KEY_HEAD = "head";
    private static final String KEY_DESCRIPTION = "description";
    private static final String KEY_LIKE = "like";
 
    public DBManager(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }
 
    @Override
    public void onCreate(SQLiteDatabase db) {
        String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME +
                "(" + KEY_ID + " INTEGER PRIMARY KEY, " + KEY_HEAD + " TEXT, " +
                KEY_DESCRIPTION + " TEXT, " + KEY_LIKE + " INTEGER PRIMARY KEY" + ")";
 
        db.execSQL(CREATE_TABLE);
    }
 
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
 
        onCreate(db);
    }
 
    public void addItem(Item item) {
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
 
        values.put(KEY_HEAD, item.getHead());
        values.put(KEY_DESCRIPTION, item.getDescription());
        values.put(KEY_LIKE, item.getLike());
 
        db.insert(TABLE_NAME, null, values);
        db.close();
    }
 
    public Item getItem(int id) {
        SQLiteDatabase db = this.getReadableDatabase();
 
        Cursor cursor = db.query(TABLE_NAME, new String[] {KEY_ID, KEY_HEAD, KEY_DESCRIPTION, KEY_LIKE}, KEY_ID + "=?", new String[] {String.valueOf(id)}, null, null, null, null );
        if(cursor != null)
            cursor.moveToFirst();
 
        Item item = new Item();
        item.setID(Integer.parseInt(cursor.getString(0)));
        item.setHead(cursor.getString(1));
        item.setDescription(cursor.getString(2));
        item.setLike(Integer.parseInt(cursor.getString(3)));
 
        return item;
    }
 
    public ArrayList<Item> getAllItems() {
        ArrayList<Item> items = new ArrayList<Item>();
 
        String selectQuery = "SELECT  * FROM " + TABLE_NAME;
 
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);
 
        if(cursor.moveToFirst())
            do {
                Item item = new Item();
                item.setID(Integer.parseInt(cursor.getString(0)));
                item.setHead(cursor.getString(1));
                item.setDescription(cursor.getString(2));
                item.setLike(Integer.parseInt(cursor.getString(3)));
                items.add(item);
            } while(cursor.moveToNext());
 
        return items;
     }
 
    public int setLikeItem(Item item) {
        SQLiteDatabase db = this.getWritableDatabase();
 
        ContentValues values = new ContentValues();
        values.put(KEY_HEAD, item.getHead());
        values.put(KEY_DESCRIPTION, item.getDescription());
        values.put(KEY_LIKE, item.getLike());
 
        return db.update(TABLE_NAME, values, KEY_ID + " = ?", new String[] { String.valueOf(item.getID()) });
    }
 
    public int getItemCount() {
        String countQuery = "SELECT  * FROM " + TABLE_NAME;
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(countQuery, null);
        cursor.close();
 
        return cursor.getCount();
    }
}
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class BrowsingActivity extends ActionBarActivity {
 
    private ListView listView;
    private CreateList listAdapter;
 
    private ArrayList<Item> list;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_browsing);
 
        DBManager db = new DBManager(this);
        db.addItem(new Item("Заголовок1", "Текст1", 0));
        db.addItem(new Item("Заголовок2", "Текст2", 0));
        db.addItem(new Item("Заголовок3", "Текст3", 0));
 
        list = db.getAllItems();
 
        listView = (ListView) findViewById(R.id.list);
        listAdapter = new CreateList(this, list);
 
    }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.03.2015, 14:14
Ответы с готовыми решениями:

Ошибка при записи данных в SQLite
Нужно добавить данные в БД SQLite, добавить нужно только текст. Проект запускается, но при нажатии на кнопку программа падает, в чем беда?...

Ошибка при создании БД
Нужно добавить данные(строка и число) в базу данных, но при создании базы данных происходит какая-то ошибка import...

Ошибка при создании файла
witeObjectToFile(user, ctx.getApplicationContext().getFilesDir() + &quot;/ds/dd.txt&quot;); public void witeObjectToFile(Object object, String...

1
914 / 562 / 88
Регистрация: 13.02.2014
Сообщений: 2,082
09.03.2015, 18:05
Лучший ответ Сообщение было отмечено MrScrat как решение

Решение

INTEGER PRIMARY KEY только один должен быть. KEY_LIKE ставь просто INTEGER.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.03.2015, 18:05
Помогаю со студенческими работами здесь

Ошибка при создании RadioButton
В OnCreate Update(&quot;studentsapp1pn.txt&quot;,(RadioGroup) findViewById(R.id.rasRgPn)); public void Update(String...

Ошибка при создании приложения
Решил научиться работать в Android Studio. Установил её, запустил, решил запустить простейшее приложение с выводом &quot;Hello...

Ошибка при создании обработчика
Извините за глупый вопрос... btnAdd.setOnClicklisteer(this) AndroidStudio ругается на этот участок кода.... Первый день работаю с java и...

Ошибка при создании виджета
Доброго времени суток! При создании виджета всегда вылетает одна и та же ошибка, подскажите пожалуйста в чем проблема: MainActivity ...

Ошибка при создании проекта
Запускаю Eclipse, создаю Android-проект (параметы: Build SDK: Android 4.1, Minimum Required SDK: Android 4.0.3, Create Activity:...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru