Не могу составить запрос к таблице

SQLite, Preferences, файлы, SD, Content Provider, XML, JSON
Ответить
george
Сообщения: 7
Зарегистрирован: 07 фев 2012, 18:46

Не могу составить запрос к таблице

Сообщение george » 11 апр 2012, 18:56

Проблема. Нужно произвести выборку по двум полям и вывести записи поля которых удовлетворяют обоим требованиям.
В теории это выглядит вот так SELECT * FROM table WHERE count=5 AND id < 100
Вот мой код:
public Cursor queueAll_time(){
int s1, s2, d1,d2,d3;
MyTimer cTimer = new MyTimer();
s1 = cTimer.setTimeHour();
s2 = cTimer.setTimeMinute();
d1 = cTimer.setDateYear();
d2 = cTimer.setDateMonth();
d3 = cTimer.setDateDay();
StringBuilder hourValue = new StringBuilder().append(s1).append(s2);
StringBuilder dataValue = new StringBuilder().append(d1).append(d2);
String where = KEY_DATA + "<" + dataValue + KEY_TIME + ">" + hourValue;

Cursor cursor = sqLiteDatabase.query(MYDATABASE_TABLE_LIST, null,

where, null, null, null, null);
return cursor;
}
Помогите пожалуйста.

Аватара пользователя
KamiSempai
Сообщения: 1339
Зарегистрирован: 17 фев 2012, 21:23
Откуда: Мордор

Re: Не могу составить запрос к таблице

Сообщение KamiSempai » 11 апр 2012, 19:19

Между условиями нужно " AND " добавить:
String where = KEY_DATA + "<" + dataValue + " AND " + KEY_TIME + ">" + hourValue;
R.id.team
Хватит таскать макулатуру на тренировку! Используй T Note.

george
Сообщения: 7
Зарегистрирован: 07 фев 2012, 18:46

Re: Не могу составить запрос к таблице

Сообщение george » 13 апр 2012, 23:32

Добавил строчку к примеру урок 34.
Приложение вылетает при выполнении запроса к бд.Без AND, с одним параметром работает.
Помогите разобраться.

public class B15TestAppActivity extends Activity implements OnClickListener {
final String LOG_TAG = "myLogs";
Button btnAdd, btnRead, btnClear;
EditText etName, etEmail;
DBHelper dbHelper;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

btnAdd = (Button) findViewById(R.id.btnAdd);
btnAdd.setOnClickListener(this);

btnRead = (Button) findViewById(R.id.btnRead);
btnRead.setOnClickListener(this);

btnClear = (Button) findViewById(R.id.btnClear);
btnClear.setOnClickListener(this);

etName = (EditText) findViewById(R.id.etName);
etEmail = (EditText) findViewById(R.id.etEmail);

// создаем объект для создания и управления версиями БД
dbHelper = new DBHelper(this);
}


@Override
public void onClick(View v) {

// создаем объект для данных
ContentValues cv = new ContentValues();

// получаем данные из полей ввода
String name = etName.getText().toString();
String email = etEmail.getText().toString();

// подключаемся к БД
SQLiteDatabase db = dbHelper.getWritableDatabase();


switch (v.getId()) {
case R.id.btnAdd:
Log.d(LOG_TAG, "--- Insert in mytable: ---");
// подготовим данные для вставки в виде пар: наименование столбца - значение

cv.put("name", name);
cv.put("email", email);
// вставляем запись и получаем ее ID
long rowID = db.insert("mytable", null, cv);
Log.d(LOG_TAG, "row inserted, ID = " + rowID);
break;
case R.id.btnRead:
Log.d(LOG_TAG, "--- Rows in mytable: ---");
// делаем запрос всех данных из таблицы mytable, получаем Cursor
String where = "email" + ">" + "14" + "AND" + "name" + "<" + "10";
Cursor c = db.query("mytable", null, where, null, null, null, null);

// ставим позицию курсора на первую строку выборки
// если в выборке нет строк, вернется false
if (c.moveToFirst()) {

// определяем номера столбцов по имени в выборке
int idColIndex = c.getColumnIndex("id");
int nameColIndex = c.getColumnIndex("name");
int emailColIndex = c.getColumnIndex("email");

do {
// получаем значения по номерам столбцов и пишем все в лог
Log.d(LOG_TAG,
"ID = " + c.getInt(idColIndex) +
", name = " + c.getString(nameColIndex) +
", email = " + c.getString(emailColIndex));
// переход на следующую строку
// а если следующей нет (текущая - последняя), то false - выходим из цикла
} while (c.moveToNext());
} else
Log.d(LOG_TAG, "0 rows");
break;
case R.id.btnClear:
Log.d(LOG_TAG, "--- Clear mytable: ---");
// удаляем все записи
int clearCount = db.delete("mytable", null, null);
Log.d(LOG_TAG, "deleted rows count = " + clearCount);
break;
}
// закрываем подключение к БД
dbHelper.close();
}

class DBHelper extends SQLiteOpenHelper {

public DBHelper(Context context) {
// конструктор суперкласса
super(context, "myDB", null, 1);
}

@Override
public void onCreate(SQLiteDatabase db) {
Log.d(LOG_TAG, "--- onCreate database ---");
// создаем таблицу с полями
db.execSQL("create table mytable ("
+ "id integer primary key autoincrement,"
+ "name text,"
+ "email text" + ");");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}
}
}

04-12 09:39:05.051: W/KeyCharacterMap(365): No keyboard for id 0
04-12 09:39:05.097: W/KeyCharacterMap(365): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
04-12 09:41:01.280: W/KeyCharacterMap(399): No keyboard for id 0
04-12 09:41:01.280: W/KeyCharacterMap(399): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
04-12 09:41:08.311: I/dalvikvm(399): threadid=4: reacting to signal 3
04-12 09:41:08.441: I/dalvikvm(399): Wrote stack traces to '/data/anr/traces.txt'
04-12 09:43:19.250: W/dalvikvm(399): threadid=1: thread exiting with uncaught exception (group=0x40015560)
04-12 09:43:19.321: E/AndroidRuntime(399): FATAL EXCEPTION: main
04-12 09:43:19.321: E/AndroidRuntime(399): android.database.sqlite.SQLiteException: unrecognized token: "14ANDname": , while compiling: SELECT * FROM mytable WHERE email>14ANDname<10
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteCompiledSql.compile(SQLiteCompiledSql.java:92)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:65)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:83)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:49)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:42)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1356)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteDatabase.queryWithFactory(SQLiteDatabase.java:1235)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1189)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1271)
04-12 09:43:19.321: E/AndroidRuntime(399): at com.b15test.B15TestAppActivity.onClick(B15TestAppActivity.java:77)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.view.View.performClick(View.java:2485)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.view.View$PerformClick.run(View.java:9080)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.os.Handler.handleCallback(Handler.java:587)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.os.Handler.dispatchMessage(Handler.java:92)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.os.Looper.loop(Looper.java:123)
04-12 09:43:19.321: E/AndroidRuntime(399): at android.app.ActivityThread.main(ActivityThread.java:3683)
04-12 09:43:19.321: E/AndroidRuntime(399): at java.lang.reflect.Method.invokeNative(Native Method)
04-12 09:43:19.321: E/AndroidRuntime(399): at java.lang.reflect.Method.invoke(Method.java:507)
04-12 09:43:19.321: E/AndroidRuntime(399): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-12 09:43:19.321: E/AndroidRuntime(399): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-12 09:43:19.321: E/AndroidRuntime(399): at dalvik.system.NativeStart.main(Native Method)
04-12 09:45:50.010: I/Process(399): Sending signal. PID: 399 SIG: 9

george
Сообщения: 7
Зарегистрирован: 07 фев 2012, 18:46

Re: Не могу составить запрос к таблице

Сообщение george » 14 апр 2012, 02:54

Заменил AND на &, приложение вылетать перестало, но запрос работает некорректно. Пишет что нет строк.

Аватара пользователя
andev
Сообщения: 219
Зарегистрирован: 13 янв 2012, 17:56

Re: Не могу составить запрос к таблице

Сообщение andev » 14 апр 2012, 09:09

верните обратно AND, обратите внимание на пробелы, как советовал KamiSempai
при конкатенации строк у вас получается

Код: Выделить всё

String where = "email>14ANDname<10";
как думаете, выполнится ?

Оно даже само пожаловалось на эту строку

Код: Выделить всё

04-12 09:43:19.321: E/AndroidRuntime(399): android.database.sqlite.SQLiteException: unrecognized token: "14ANDname": , while compiling: SELECT * FROM mytable WHERE email>14ANDname<10

Аватара пользователя
KamiSempai
Сообщения: 1339
Зарегистрирован: 17 фев 2012, 21:23
Откуда: Мордор

Re: Не могу составить запрос к таблице

Сообщение KamiSempai » 14 апр 2012, 10:39

andev писал(а):верните обратно AND, обратите внимание на пробелы, как советовал KamiSempai
Да, нужно было сразу внимание на это обратить. Так и знал, что пробелы не заметит :)
R.id.team
Хватит таскать макулатуру на тренировку! Используй T Note.

george
Сообщения: 7
Зарегистрирован: 07 фев 2012, 18:46

Re: Не могу составить запрос к таблице

Сообщение george » 14 апр 2012, 15:12

Спасибо большое. Все заработало. С пробелами теперь буду внимательней.

Ответить