Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 09.04.2015
Сообщений: 89
1

Как добавить запись в готовую подключённую БД

29.07.2015, 13:20. Показов 644. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Проект залили на файлообменник.

меня 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.07.2015, 13:20
Ответы с готовыми решениями:

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

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

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

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

0
29.07.2015, 13:20
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.07.2015, 13:20
Помогаю со студенческими работами здесь

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

Добавить процедуру в готовую программу
Помогите надо в эту программу добавить процедуру создать процедуру поиска и вывода сотрудниц страше...

Добавить в готовый модуль готовую процедуру
Есть модуль, который заменяет букву &quot;а&quot; на &quot;+&quot;. unit qwerty; interface procedure...

Добавить готовую страницу на существующий сайт
Доброго дня господа. Мне понадобилось на сайте устроить возможность подбора номера с помощью маски,...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru