Форум программистов, компьютерный форум CyberForum.ru

Как добавить запись в готовую подключённую БД - Программирование Android

Войти
Регистрация
Восстановить пароль
Другие темы раздела
Программирование Android Отслеживание нажатия кнопки http://www.cyberforum.ru/android-dev/thread1506643.html
В приложении присутствует две кнопки и один долгий цикл. Нужно ли отслеживать нажатие кнопки при выполнении цикла или андроид сам прервет цикл для обработки нажатия. И достаточно ли будет такого кода, чтобы остановить цикл при нажатии. public void onClick(View v) { break; }
Программирование Android Как распаковать hidden.img.ext4 Возникла необходимость изменить содержание упаковки hidden.img.ext4. Упаковка является частью ПО для прошивки телефона Samsung Galaxy Mega GT019200. Не знаю как подступиться к этому пакету. А надо распаковать, удалить лишнее, а затем запаковать обратно и вставить в прошивку. Подскажите хоть что-нибудь для начала. http://www.cyberforum.ru/android-dev/thread1506565.html
Загрузить картинку в Drawable Программирование Android
И так. Смотрите, дефолтные картинки я кидаю в Draweable. И их от туда беру. Как бы мне взять картинку динамически? Ну смотрите, пользователь закинул выбранные картинки к примеру в папку MyPhoto (Которая в корне создала программа). И от туда я уже мог подгрузить картинки. Либо подскажите решение по лучше. Суть в том, что мне нужно создать определенный альбом для пользователя и там в том...
Нужна консультация по андроид Программирование Android
Пишу ТЗ на софт и возник нубский вопрос. Некоторые настройки приложение будет считывать с текстового файла который будет находится в папке /res в .Аpk Если внести изменения в этот текстовый файл напрямую без пере-компиляции всего приложения, а потом только пере-подписать apk, приложение будет рабочим ? Я протестировал со сменой картинок и приложение осталось рабочим, а вот с текстовыми не...
Программирование Android Как прикрутить "свой браузер" к странице - "фрагмент" http://www.cyberforum.ru/android-dev/thread1506411.html
здравствуйте. все, уже голову сломал. не соображаю совсем. не получается прикрутить код браузера к странице fragments.выводиться должно на- R.layout.news. обложка программы "боковое слайдер-меню". выдвинул слайдер, там кликнул. загрузилась страница Новости, которая автоматом загружает страницу с сайта. код News.java который открывает страницу package com.example.pinsklife.pl3.fragments;...
Программирование Android Не получается (де)сериализации класса Классы public class FirstClass implements Serializable{ String ; int ; public void Print(){...} } public class SecondClass implements Serializable { String ; подробнее

Показать сообщение отдельно
Soprano6111
2 / 2 / 0
Регистрация: 09.04.2015
Сообщений: 90

Как добавить запись в готовую подключённую БД - Программирование Android

29.07.2015, 13:20. Просмотров 345. Ответов 0
Метки (Все метки)

Проект залили на файлообменник.

меня 2е загвоздки :

1) в классе IdevOwnSqliteDbActivity

Метод - onClick , не заносятся поля функцией addContact , не могу понять что не так.

2) хочу сделать переход - чтение как в этой теме(Android, готовая база sql
) - из одного ListView в другой

Java
1
2
3
4
5
6
public void onListItemClick(ListView parent, View view, int position, long id) {
Intent intent = new Intent(this, DataActivity.class);
Cursor cursor = (Cursor) adapter.getItem(position);
intent.putExtra("PEPAK_ID", cursor.getInt(cursor.getColumnIndex("_id")));
startActivity(intent);
}
Здесь он передаёт _id в другую активность

и там выводит данные из таблицы при переходе на активность->

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
long id = getIntent().getLongExtra("_id",-6);
//Наш ключевой хелпер
ExternalDbOpenHelper dbOpenHelper = new ExternalDbOpenHelper(this, DB_NAME);
database = dbOpenHelper.openDataBase();
//Все, база открыта!
Cursor c = database.query(TABLE_NAME, new String[] {FRIEND_ID, FRIEND_ALL},
null, null,null,null,FRIEND_ALL);
TextView lv = (TextView) findViewById(R.id.text1);
 
//выводим все в текствьюхи
if (c.moveToFirst()) {
 
lv.setText(c.getString(c.getColumnIndex(FRIEND_ALL)));
}
dbOpenHelper.close();
database.close();
Добавлено через 1 минуту
Не знаю может будет удобно отображу тут 3и класса что есть в проекте :

DatabaseHelper

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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
package by.idev.android.ownsqlitedb.activity;
 
        import java.io.FileOutputStream;
        import java.io.IOException;
        import java.io.InputStream;
        import java.io.OutputStream;
        import java.util.ArrayList;
        import java.util.List;
 
        import android.content.ContentValues;
        import android.content.Context;
        import android.database.Cursor;
        import android.database.SQLException;
        import android.database.sqlite.SQLiteDatabase;
        import android.database.sqlite.SQLiteOpenHelper;
        import android.provider.BaseColumns;
        import android.util.Log;
 
public class DatabaseHelper extends SQLiteOpenHelper  { //implements BaseColumns
 
 
    public static String DB_PATH;
 
    //public static String DB_NAME;
    public SQLiteDatabase database;
    public final Context context;
    //private static final String DB_NAME = "sprinkle.sqlite";
    //public static String DB_NAME;
    private static final String DB_NAME = "yourdb.sqlite3";//sprinkle.sqlite
    private static final String TABLE_NAME = "friends";//shedules
    public static final String COLUMN_ID =  "_id";
    private static final String FRIEND_NAME = "name";
    public SQLiteDatabase getDb() {
        return database;
    }
 
    public DatabaseHelper(Context context, String databaseName) {
        super(context, databaseName, null, 1);
        this.context = context;
 
        String packageName = context.getPackageName();
        DB_PATH = String.format("//data//data//%s//databases//", packageName);
        //DB_NAME = databaseName;
        openDataBase();
    }
 
 
    public void createDataBase() {
        boolean dbExist = checkDataBase();
        if (!dbExist) {
            this.getReadableDatabase();
            try {
                copyDataBase();
            } catch (IOException e) {
                Log.e(this.getClass().toString(), "Copying error");
                throw new Error("Error copying database!");
            }
        } else {
            Log.i(this.getClass().toString(), "Database already exists");
        }
    }
 
    private boolean checkDataBase() {
        SQLiteDatabase checkDb = null;
        try {
            String path = DB_PATH + DB_NAME;
            checkDb = SQLiteDatabase.openDatabase(path, null,
                    SQLiteDatabase.OPEN_READONLY);
        } catch (SQLException e) {
            Log.e(this.getClass().toString(), "Error while checking db");
        }
 
        if (checkDb != null) {
            checkDb.close();
        }
        return checkDb != null;
    }
 
    private void copyDataBase() throws IOException {
 
 
        InputStream externalDbStream = context.getAssets().open(DB_NAME);
 
 
        String outFileName = DB_PATH + DB_NAME;
 
        OutputStream localDbStream = new FileOutputStream(outFileName);
 
 
        byte[] buffer = new byte[1024];
        int bytesRead;
        while ((bytesRead = externalDbStream.read(buffer)) > 0) {
            localDbStream.write(buffer, 0, bytesRead);
        }
 
        localDbStream.close();
        externalDbStream.close();
 
    }
 
    public SQLiteDatabase openDataBase() throws SQLException {
        String path = DB_PATH + DB_NAME;
        if (database == null) {
            createDataBase();
            database = SQLiteDatabase.openDatabase(path, null,
                    SQLiteDatabase.OPEN_READWRITE);
        }
        return database;
    }
    @Override
    public synchronized void close() {
        if (database != null) {
            database.close();
        }
        super.close();
    }
    @Override
    public void onCreate(SQLiteDatabase db) {}
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }
 
    // Добавляем новый контакт
    public void addContact(Contact contact) {
        SQLiteDatabase db = this.getWritableDatabase();
 
        ContentValues values = new ContentValues();
        values.put(FRIEND_NAME, contact.getName());
        //values.put(COLUMN_PHONE, contact.getPhoneNumber());
    //  values.put(COLUMN_AGE, contact.getAge());
 
        // Вставляем строку в таблицу
        db.insert(TABLE_NAME, null, values);
        db.close();
    }
 
    // Получить контакт
    public Contact getContact(int id) {
        SQLiteDatabase db = this.getReadableDatabase();
 
        Cursor cursor = db.query(TABLE_NAME, new String[] { COLUMN_ID,
                        FRIEND_NAME }, COLUMN_ID + "=?",
                new String[] { String.valueOf(id) }, null, null, null, null);
        if (cursor != null)
            cursor.moveToFirst();
 
        Contact contact = new Contact(Integer.parseInt(cursor.getString(0)),
                cursor.getString(1));//, cursor.getString(2), Integer.parseInt(cursor.getString(3))
        return contact;
    }
 
    // Получить все контакты
    public List<Contact> getAllContacts() {
        List contactList = new ArrayList<>();
        // Выбираем всю таблицу
        String selectQuery = "SELECT * FROM " + TABLE_NAME;
 
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);
 
        // Проходим по всем строкам и добавляем в список
        if (cursor.moveToFirst()) {
            do {
                Contact contact = new Contact();
                //contact.setID(Integer.parseInt(cursor.getString(0)));
                contact.setName(cursor.getString(2));
                //contact.setPhoneNumber(cursor.getString(2));
                //contact.setAge(Integer.parseInt(cursor.getString(3)));
                contactList.add(contact);
            } while (cursor.moveToNext());
        }
        cursor.close();
        return contactList;
    }
 
    // Получить число контактов
    public int getContactsCount() {
        String countQuery = "SELECT * FROM " + TABLE_NAME;
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(countQuery, null);
        int count = cursor.getCount();
 
        cursor.close();
 
        return count;
    }
 
    // Обновить контакт
    public int updateContact(Contact contact) {
        SQLiteDatabase db = this.getWritableDatabase();
 
        ContentValues values = new ContentValues();
        values.put(FRIEND_NAME, contact.getName());
 
 
        // обновляем строку
        return db.update(TABLE_NAME, values, COLUMN_ID + " = ?",
                new String[] { String.valueOf(contact.getID()) });
    }
 
    // Удалить контакт
    public void deleteContact(Contact contact) {
        SQLiteDatabase db = this.getWritableDatabase();
        db.delete(TABLE_NAME, COLUMN_ID + " = ?",
                new String[] { String.valueOf(contact.getID()) });
        db.close();
    }
 
 
}
Добавлено через 50 секунд
Contact
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
package by.idev.android.ownsqlitedb.activity;
 
public class Contact {
 
    private int _id;
    private String mName;
    //  private String mPhoneNumber;
    //  private int mAge;
 
    // Пустой констуктор
    public Contact() {
 
    }
 
    // Конструктор с параметрами
    public Contact(int id, String name) {//, String phonenumber, int age
        this._id = id;
        this.mName = name;
        //  this.mPhoneNumber = phonenumber;
        //   this.mAge = age;
    }
 
    // Конструктор с параметрами
    public Contact(String name) { //, String phonenumber, int age
        this.mName = name;
        //   this.mPhoneNumber = phonenumber;
        //   this.mAge = age;
    }
 
    // Создание геттеров-сеттеров
 
    public int getID() {
        return this._id;
    }
 
    public void setID(int id) {
        this._id = id;
    }
 
    public String getName() {
        return this.mName;
    }
    @Override
    public String toString() {
        return this.mName/* + " (" + this.mPhoneNumber + ")"*/;
    }
    public void setName(String name) {
        this.mName = name;
    }
 
    //  public String getPhoneNumber() {
    //      return this.mPhoneNumber;
    //  }
 
    // public void setPhoneNumber(String phonenumber) {
    //    this.mPhoneNumber = phonenumber;
    // }
 
    // public int getAge() {
    //   return this.mAge;
    //}
 
    //public void setAge(int age) {
    //    this.mAge = age;
    // }
}
Добавлено через 2 минуты
IdevOwnSqliteDbActivity

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
package by.idev.android.ownsqlitedb.activity;
 
import android.app.ListActivity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
 
import java.util.ArrayList;
import java.util.List;
 
import by.idev.android.ownsqlitedb.R;
 
public class IdevOwnSqliteDbActivity extends ListActivity {
    private static final String DB_NAME = "yourdb.sqlite3";//sprinkle.sqlite
    private EditText editText;
    private static final String TABLE_NAME = "friends";//shedules
    private static final String FRIEND_ID = "_id";
    private static final String FRIEND_NAME = "name";
 
    private SQLiteDatabase database;
    private ListView listView;
    private ArrayList<String> friends;
  //  DatabaseHelper dbOpenHelper = new DatabaseHelper(this, DB_NAME);
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        editText = (EditText) findViewById(R.id.editText);
 
        DatabaseHelper dbOpenHelper = new DatabaseHelper(this, DB_NAME);
        database = dbOpenHelper.openDataBase();
        dbOpenHelper.addContact(new Contact("One"));
        dbOpenHelper.addContact(new Contact("Two"));
        dbOpenHelper.addContact(new Contact("Tree"));
        dbOpenHelper.addContact(new Contact("Fore"));
        fillFreinds();
        setUpList();
    }
 
    private void setUpList() {
 
        setListAdapter(new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1, friends));
        listView = getListView();
 
 
        listView.setOnItemClickListener(new OnItemClickListener() {
            public void onItemClick(AdapterView<?> parent, View view,
                                    int position,long id) {
                Toast.makeText(getApplicationContext(),
                        ((TextView) view).getText() +
                                " could be iDev's friend",
                        Toast.LENGTH_SHORT).show();
            }
        });
    }
 
 
    private void fillFreinds() {
        friends = new ArrayList<String>();
        Cursor friendCursor = database.query(TABLE_NAME,
                new String[]
                        {FRIEND_ID, FRIEND_NAME},
                null, null, null, null
                , FRIEND_NAME);
        friendCursor.moveToFirst();
        if(!friendCursor.isAfterLast()) {
            do {
                String name = friendCursor.getString(1);
                friends.add(name);
            } while (friendCursor.moveToNext());
        }
        friendCursor.close();
    }
 
    public void onClick(View view) {
        DatabaseHelper dbOpenHelper = new DatabaseHelper(this, DB_NAME);
        //String g = String.valueOf(editText.getText());
        dbOpenHelper.addContact(new Contact("POPURMENU"));
    }
 
    public void onClick2(View view) {
        // Считываем все контакты
        DatabaseHelper dbOpenHelper = new DatabaseHelper(this, DB_NAME);
        List<Contact> contacts = dbOpenHelper.getAllContacts();
 
        ArrayAdapter<Contact> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1,
               android.R.id.text1, contacts);
 
        listView.setAdapter(adapter);
 
    }
}
Добавлено через 5 минут
http://rghost.ru/8gncXbvWD Ссылка на проект
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru