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

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

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

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

29.07.2015, 13:20. Просмотров 363. Ответов 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 Ссылка на проект
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.07.2015, 13:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Как добавить запись в готовую подключённую БД (Программирование Android):

Как подключить готовую базу Sqlite на проект - Программирование Android
Привет друзья. Я учусь программировать под андроид и много чего прочитал с интернета все равно там непонятно. То есть у кого нибудь есть...

Объясните как подключить готовую БД с двумя и больше таблицами - Программирование Android
Здравствуйте. Я новичок, поэтому рассчитываю на вашу помощь. В программе нужно, чтобы в одном активити в лист вставлялись данные из одной...

Как быстро подключить готовую БД SQLite к проекту Android - Программирование Android
Решил написать мини гайд по подключению готовой БД, мне это пригодится неоднократно, надеюсь кому-то будет полезно: Создать папку...

Как правильно добавить строки в готовую БД Access ? - MS Access
Всем Доброго времени ! Есть база данных в ACCESS из 5-ти таблиц. На основе этой БД работает ПРОГРАММА Отчетов. Опыт работы в Access –...

Как добавить вновь созданное поле в уже готовую форму? - MS Access
Подскажите пожалуйста возможен ли (и как это сделать) ввод нового поля в уже созданную форму. Т.е. в таблице добавила новое поле для...

Подскажите пожалуйста как добавить конструктор копирования в готовую программу - C++
Вот код программы: # include &lt;iostream&gt; # include &lt;conio.h&gt; # include &lt;string&gt; # include &lt;stdio.h&gt; # include &lt;cstdlib&gt; ...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.07.2015, 13:20
Привет! Вот еще темы с ответами:

Добавить в готовую бд компоненты - Delphi БД
помогите пожалуйста, добавить в готовую бд компоненты OpenDialog(добавить) и SaveDialog(сохранить).

Добавить данные в готовую программу - C#
Есть программа шифратор, нужно, что-бы при первом старте просила ввести ключ шифровки/расшифровки. Реально ли сделать так, что программа...

Добавить процедуру в готовую программу - Pascal ABC
Помогите надо в эту программу добавить процедуру создать процедуру поиска и вывода сотрудниц страше 50 лет. program Kursova; ...

Добавить в готовый модуль готовую процедуру - Turbo Pascal
Есть модуль, который заменяет букву &quot;а&quot; на &quot;+&quot;. unit qwerty; interface procedure zamena(var s : string); ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

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