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

Программирование Android

Войти
Регистрация
Восстановить пароль
 
Soprano6111
2 / 2 / 0
Регистрация: 09.04.2015
Сообщений: 90
#1

Как добавить запись в готовую подключённую БД - Программирование 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 Ссылка на проект
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.07.2015, 13:20     Как добавить запись в готовую подключённую БД
Посмотрите здесь:
Как подключить готовую базу Sqlite на проект Android
Как быстро подключить готовую БД SQLite к проекту Android Android
Объясните как подключить готовую БД с двумя и больше таблицами Android
Android Как добавить фильтр?
Android Как добавить SurfaceView в разметку
Как добавить в ListView subitem Android
Как добавить Графику в активити? Android
Android Как добавить версию андроид
Android Как добавить перенос строки?
Как добавить данный метод? Android
Как добавить событие в календарь Android
Android Как добавить OnClickListener в toast?

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru