Как добавить запись в готовую подключённую БД
29.07.2015, 13:20. Показов 644. Ответов 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
|