2014-11-04 2 views
0

Я ищу, чтобы обновить строку в базе данных SQLite. мне интересно, могу ли я обновить строку без ввода пользователя в строке? Мой код в настоящий момент требует, чтобы rowId передавался в DBAdapter, но я хотел бы устранить это и просто обновить строку, используя две другие переменные (элемент и литры). Возможно ли это?Обновление строки ввода SQLite

Это моя функция обновления в моем классе DBAdapter

//---updates a record--- 
public boolean updateRecord(long rowId, String item, String litres) 
{ 
    ContentValues args = new ContentValues(); 
    args.put(KEY_ITEM, item); 
    args.put(KEY_LITRES, litres); 
    return db.update(DATABASE_TABLE, args, KEY_ROWID + "=" + rowId, null) > 0; 
} 

это мой класс обновления,

package com.example.rory.dbtest; 

import android.app.Activity; 
import android.content.Intent; 
import android.os.Bundle; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 

import com.pinchtapzoom.R; 


public class Update extends Activity { 

public EditText updateItem; 
public EditText updateLitres; 
Button updateBtn; 

DBAdapter db = new DBAdapter(this); 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_update); 

    updateBtn = (Button)findViewById(R.id.updateBtn); 
    updateItem = (EditText)findViewById(R.id.updateItem); 
    updateLitres = (EditText)findViewById(R.id.updateLitres); 
} 


public void onClick(View v) 
{ 
    String item = updateItem.getText().toString(); 
    String litres = updateLitres.getText().toString(); 
    db.updateRecord(rowId, String item, String litres); 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.update, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    // Handle action bar item clicks here. The action bar will 
    // automatically handle clicks on the Home/Up button, so long 
    // as you specify a parent activity in AndroidManifest.xml. 
    int id = item.getItemId(); 
    if (id == R.id.action_settings) { 
     return true; 
    } 
    return super.onOptionsItemSelected(item); 
} 

//returning to the first activity, when here this calls the running functions ie. printing records 
public void viewAssignments(View v) 
{ 
    Intent i = new Intent(this, MyActivity.class); 
    startActivity(i); 
} 
} 
+0

Какое же единственное ограничение в том, где предложение? – Amy

+0

Могу ли я изменить ограничение на возврат db.update (DATABASE_TABLE, args, KEY_ITEM + "=" + item, null)> 0; –

+0

это то, что я изменил функцию обновления в моем DBAdapter, и теперь я только передаю два значения, но я получаю сообщение об ошибке для этого общедоступного логического обновленияRecord (String item, String liters) { ContentValues ​​args = new ContentValues ​​(); args.put (KEY_ITEM, элемент); args.put (KEY_LITRES, литры); return db.update (DATABASE_TABLE, args, KEY_ITEM + "=" + item, null)> 0; } ' –

ответ

0

Я использую этот раздел кода в моем проекте.

@Override 
    public int update(Uri uri, ContentValues values, String selection, 
      String[] selectionArgs) { 
      String sql = "UPDATE table_name SET product_qty = \'"+values.getAsString("product_qty")+"\' Where row_id = \'"+selectionArgs[0]+"\'"+" ; "; 

      Log.e("sql", sql) ; 

      db_cc.getWritableDatabase().execSQL(sql); 

      return 0; 
    } 

Где я передаю мой ROW_ID в [0] й позиции массива selectionArgs, и в моем случае я хочу, чтобы обновить product_qty так я прошел эту величину с помощью ContentValues.

+0

, так вы используете этот код для обновления, используя product_qty, а не row_id? –

+0

нет, я использую условие Где row_id = \ '"+ selectionArgs [0], затем установка product_qty = \'" + values.getAsString ("product_qty") –

0

Вы можете сделать RAW Обновления так же легко, как это:

public boolean updateRecord(String item, String litres) 
{ 
    return db.execSQL("UPDATE "+DATABASE_TABLE+" SET "+KEY_LITRES+"='"+litres+"' WHERE "+KEY_ITEM+"='"+item+"'") 
} 

Но это обновит все строки с KEY_ITEM = пункт условия ИЛИ ... Вы можете добавить еще один параметр, например:

, и это будет обновлять только строку с заданными параметрами элемента и литра НО, если у вас есть 2 или более строк с одинаковыми элементами и литрами, тогда возникнет проблема.

Я по-прежнему рекомендую вместо этого использовать уникальные ключи или первичные ключи.

+0

спасибо за ответ, я немного не уверен в этом, может вы скажете мне, правильно ли я говорю, что, заменив мою функцию обновления этим кодом в моем классе DBAdapter, вызывая эту функцию в моем классе обновления и отправляя правильные переменные, она обновит запись? –

+0

thats right Hayes121, вы первоначально отправляете 3 параметра в свою функцию updateRecord(), поэтому я думаю, что если вы хотите не включать rowId, а два других параметра, то это ваш ответ, но, если быть более конкретным, вы можете включить третью (newLitres), если хотите изменить это значение. –

+0

круто спасибо, последнее, когда я ввел в код, который вы указали выше, он дает мне красную строку ошибки под всем текстом, в котором говорится, что для нее требуется логическое значение и она становится пустой, чтобы исправить это, я думал, что я хочу просто поместите dbexecSQL в логическое значение, но это не сработало, любые идеи, как это исправить? –

Смежные вопросы