Урок 35. SQLite. Методы update и delete с указанием условия
Re: Урок 35. SQLite. Методы update и delete с указанием усло
У меня в приложении будет несколько Activity, поочередно работающих с базой данных.
Вопрос: когда я подключаюсь к БД в главной Activity, это подключение создается для приложения в целом или только для текущей Activity?
Т.е. надо ли переподключаться при смене Activity, и что происходит с текущим подключением, когда я перемещаюсь между разными активностями?
Вопрос: когда я подключаюсь к БД в главной Activity, это подключение создается для приложения в целом или только для текущей Activity?
Т.е. надо ли переподключаться при смене Activity, и что происходит с текущим подключением, когда я перемещаюсь между разными активностями?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
При создании таблицы через execSQL, если она уже существует, это вежливо сообщается в логе:
INFO/Database(6461): sqlite returned: error code = 1, msg = table newTable already exists
Как бы программно организовать эту проверочку?
INFO/Database(6461): sqlite returned: error code = 1, msg = table newTable already exists
Как бы программно организовать эту проверочку?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
несколько примеров, которые легко нагуглить.Isaev писал(а):При создании таблицы через execSQL, если она уже существует, это вежливо сообщается в логе:
INFO/Database(6461): sqlite returned: error code = 1, msg = table newTable already exists
Как бы программно организовать эту проверочку?
Когда выкладываете код на форум - код оформляйте. Редактор - поищите слова Geshi Syntax -Java. (или xml)
Свои сообщения можно редактировать - кнопка edit.
Свои сообщения можно редактировать - кнопка edit.
Re: Урок 35. SQLite. Методы update и delete с указанием усло
не верь сообщению выше.Isaev писал(а):При создании таблицы через execSQL, если она уже существует, это вежливо сообщается в логе:
INFO/Database(6461): sqlite returned: error code = 1, msg = table newTable already exists
Как бы программно организовать эту проверочку?
http://www.sqlite.org/lang_createtable.html
используй
CREATE TABLE IF NOT EXISTS...........................
R.id.team
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Здравствуйте, я новичок. Вопрос по уроку следующий:
Мы добавили новый edittext ID, куда вписываем ID для записи бд, но код при нажатии кнопки add у нас не поменялся. Т.е. я создаю запись с ID 3, а в базу все равно пишется запись с id 1.(база была пуста) Делаю новую запись с ID 7, но пишет в базу эту запись с Id 2. Однако в уроке создались записи с теми ID, которые были указаны в etID(3 и 4 соответственно). Чем это можно объяснить?
Мы добавили новый edittext ID, куда вписываем ID для записи бд, но код при нажатии кнопки add у нас не поменялся. Т.е. я создаю запись с ID 3, а в базу все равно пишется запись с id 1.(база была пуста) Делаю новую запись с ID 7, но пишет в базу эту запись с Id 2. Однако в уроке создались записи с теми ID, которые были указаны в etID(3 и 4 соответственно). Чем это можно объяснить?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Updt. Кажется я понял, когда мы базу почистили с помощью clear счетчик id не сбросился, поэтому в уроке новые записи начинались с 3 и 4. Я же запустил приложение на другом эмуляторе и база создалась новая. Вопрос, а как сделать так, чтобы новые записи записывались с ID из edittext?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
[syntax=java]db.execSQL("create table mytable ("DmitryR писал(а):Updt. Кажется я понял, когда мы базу почистили с помощью clear счетчик id не сбросился, поэтому в уроке новые записи начинались с 3 и 4. Я же запустил приложение на другом эмуляторе и база создалась новая. Вопрос, а как сделать так, чтобы новые записи записывались с ID из edittext?
+ "id integer primary key autoincrement,"
+ "name text,"
+ "email text" + ");");[/syntax]
autoincrement- говорит о том, что компьютер будет вставлять значения по порядку, в это поле.
Если хотите самостоятельно его заполнять, тогда при создании таблицы нужно написать:
id integer primary key
т.е. без autoincrement
Когда выкладываете код на форум - код оформляйте. Редактор - поищите слова Geshi Syntax -Java. (или xml)
Свои сообщения можно редактировать - кнопка edit.
Свои сообщения можно редактировать - кнопка edit.
Re: Урок 35. SQLite. Методы update и delete с указанием усло
даже если и автоинкремент, все равно можно указывать свои id.
И второе.. иногда лучше на вопрос вовсе не отвечать. ПО-моему, из вопросов как такой следует, что человек просто скопировал код с урока и даже не потрудился вдуматься в то, что там между блоками кода написано.
Не торопитесь, trew. Иной раз вы скорым предложением кода не делаете человеку лучше..
И второе.. иногда лучше на вопрос вовсе не отвечать. ПО-моему, из вопросов как такой следует, что человек просто скопировал код с урока и даже не потрудился вдуматься в то, что там между блоками кода написано.
Не торопитесь, trew. Иной раз вы скорым предложением кода не делаете человеку лучше..
R.id.team
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Где можно по подробнее прочитать про условия для upgrade?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Например в уроке 39.Mamapapa писал(а):Где можно по подробнее прочитать про условия для upgrade?
Когда выкладываете код на форум - код оформляйте. Редактор - поищите слова Geshi Syntax -Java. (или xml)
Свои сообщения можно редактировать - кнопка edit.
Свои сообщения можно редактировать - кнопка edit.
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Добрый день.
столкнулся с проблемой обновления всех строк в таблице по определенному условию:
Где я туплю?
столкнулся с проблемой обновления всех строк в таблице по определенному условию:
Код: Выделить всё
sqlQuery = "UPDATE JURNAL_N SET _id_New_Old= 2 WHERE JURNAL_N._id_New_Old =1";
db.zapros_update(sqlQuery);
Сам запрос в редакторе SQL на базе отрабатывает, а на андроиде не чего не происходит, ошибок не выдает.public void zapros_update(String sqlQuery) {
mDB.rawQuery(sqlQuery, null);
}
Где я туплю?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Я так понимаю что mDB.rawQuery(sqlQuery, null) - возвращает курсор, а что мне тогда нужно использовать?
P.S.
Нужно было просто подумать.......
и использовать mDB.execSQL(sqlQuery);
P.S.
Нужно было просто подумать.......
и использовать mDB.execSQL(sqlQuery);
Re: Урок 35. SQLite. Методы update и delete с указанием усло
используй http://developer.android.com/reference/ ... ml#execSQL(java.lang.String, java.lang.Object[])
и вообще разберись с данными, выведи запрос в лог, проведи его на тех же самых данных, что и в устройстве (эмуляторе). Неизвестно что у тебя там происходит.
и вообще разберись с данными, выведи запрос в лог, проведи его на тех же самых данных, что и в устройстве (эмуляторе). Неизвестно что у тебя там происходит.
R.id.team
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Сам спросил, сам ответил....Foenix писал(а):используй.......
Пост выше.
Нужно было использовать mDB.execSQL(sqlQuery);
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Доброго времени суток
написал метод удаления строк:
[syntax=java]public int delete(String namedell){
int col;
return col = getWritableDatabase().delete(TIME_TABLE, NUM_DET + "=" + namedell, null);
}[/syntax]
Ругается на синтаксис:
05-06 15:47:06.856: E/AndroidRuntime(739): android.database.sqlite.SQLiteException: near ".182": syntax error (code 1): , while compiling: DELETE FROM tiemtable WHERE numdet=14016.45.182
Это как понять?
написал метод удаления строк:
[syntax=java]public int delete(String namedell){
int col;
return col = getWritableDatabase().delete(TIME_TABLE, NUM_DET + "=" + namedell, null);
}[/syntax]
Ругается на синтаксис:
05-06 15:47:06.856: E/AndroidRuntime(739): android.database.sqlite.SQLiteException: near ".182": syntax error (code 1): , while compiling: DELETE FROM tiemtable WHERE numdet=14016.45.182
Это как понять?
Re: Урок 35. SQLite. Методы update и delete с указанием усло
Что-то с форматом namedellalexmx писал(а):Доброго времени суток
написал метод удаления строк:
[syntax=java]public int delete(String namedell){
int col;
return col = getWritableDatabase().delete(TIME_TABLE, NUM_DET + "=" + namedell, null);
}[/syntax]
Ругается на синтаксис:
05-06 15:47:06.856: E/AndroidRuntime(739): android.database.sqlite.SQLiteException: near ".182": syntax error (code 1): , while compiling: DELETE FROM tiemtable WHERE numdet=14016.45.182
Это как понять?
Какой формат у NUM_DET ?
Немного красивший вариант
Код: Выделить всё
public boolean deleteRow(String nameDell)
{
db.delete(TIME_TABLE, NUM_DET + "=" + nameDell, null) > 0;
}
Java Core -> JDBC -> GoF -> Android SDK ->...
Телепрограмма в твоем смарте Телепрограмма
Телепрограмма в твоем смарте Телепрограмма
Re: Урок 35. SQLite. Методы update и delete с указанием усло
в кавычках пиши
R.id.team
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
Re: Урок 35. SQLite. Методы update и delete с указанием усло
[syntax=java]static final String NUM_DET = "numdet";[/syntax]Что-то с форматом namedell
Какой формат у NUM_DET ?
В общем задача немного другая: я суммирую строки в запросе и хочу получить количество сложенных строк в группе пошарив ни чего не нашел, вот и решил получать количество через удаление
Тут произвожу операцию:
[syntax=java] int col;
c = db.query();
while (c.moveToNext()) {
idname = c.getInt(c.getColumnIndex(TIME_ID));
name = c.getString(c.getColumnIndex(NUM_DET));
sG0 = c.getDouble(c.getColumnIndex(COMMAND_G0));
sG1 = c.getDouble(c.getColumnIndex(COMMAND_G1));
sG1v = c.getDouble(c.getColumnIndex(COMMAND_G1_V));
sG1n = c.getDouble(c.getColumnIndex(COMMAND_G1_N));
sG94 = c.getDouble(c.getColumnIndex(COMMAND_G94));
sG23 = c.getDouble(c.getColumnIndex(COMMAND_G23));
sG23v = c.getDouble(c.getColumnIndex(COMMAND_G23_V));
sG23n = c.getDouble(c.getColumnIndex(COMMAND_G23_N));
System.out.println(name + " " + sG0 + " " + sG1 + " " + sG94 + " " + sG23);
col = db.delete(name);
System.out.println("delete");
}[/syntax]
Метод суммирующего запроса:
[syntax=java]public Cursor query(){
columns = new String[]{"_id", "numdet", "sum(g0) as g0", "sum(g1) as g1", "sum(g1v) as g1v",
"sum(g1n) as g1n", "sum(g94) as g94", "sum(g23) as g23", "sum(g23v) as g23v", "sum(g23n) as g23n"};
groupBy = "numdet";
return getWritableDatabase().query(TIME_TABLE, columns, null, null, groupBy, null, null);
}[/syntax]
Метод отдающего количество строк:
[syntax=java]public int delete(String namedell){
int col;
return col = getWritableDatabase().delete(TIME_TABLE, NUM_DET + "=" + namedell, null);
}[/syntax]
Re: Урок 35. SQLite. Методы update и delete с указанием усло
ничего не поняла. Что ты удаляешь??
R.id.team
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198
Re: Урок 35. SQLite. Методы update и delete с указанием усло
я удаляю строки содержащие одинаковое значение поля NUM_DET
значение этого поля переменная namedell
значение этого поля переменная namedell