【问题标题】:How can I update and delete data in listview on longpress如何在长按列表视图中更新和删除数据
【发布时间】:2019-08-08 14:39:01
【问题描述】:

我在列表视图中有一些记录,当我长按列表的特定项目时,我想更新和删除这些记录。 Like this structure DBHelper1DBHelper2DBHelper3DBHelper4DBHelper5 DBHelper6

包 com.example.loginproject.model; 公共类记录 {

String lead;
String name;
String mobile;
public Record(String lead, String name, String mobile) {
    this.lead = lead;
    this.name = name;
    this.mobile = mobile;
}
public String getLead() {
    return lead;
}
public Record(){}
public void setLead(String lead) {
    this.lead = lead;
}
public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}
public String getMobile() {
    return mobile;
}
public void setMobile(String mobile) {
    this.mobile = mobile;

}}

公共类 MyAdapter 扩展 BaseAdapter {

Context context;
ArrayList<Record> arrayList;

public  MyAdapter(Context context,ArrayList<Record>arrayList){

    this.context=context;
    this.arrayList=arrayList;
}

@Override
public int getCount() {
    return this.arrayList.size();
}

@Override
public Object getItem(int position) {
    return arrayList.get(position);
}

@Override
public long getItemId(int position) {
    return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {

        LayoutInflater layoutInflater=(LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        convertView= layoutInflater.inflate(R.layout.custom_list_view,null);
        TextView textView1 =(TextView)convertView.findViewById(R.id.textview_leads);
        TextView textView2 =(TextView)convertView.findViewById(R.id.textview_names);
        TextView textView3 =(TextView)convertView.findViewById(R.id.textview_company);


        Record record=arrayList.get(position);
        textView1.setText(record.getLead());
        textView2.setText(record.getName());
        textView3.setText(record.getMobile());

    return convertView;
}

}

公共类 Home 扩展 AppCompatActivity {

TextView Name;
Button refresh,addlead;
DatabaseHelper databaseHelper;
SQLiteOpenHelper sqLiteOpenHelper;
SQLiteDatabase db;
ListView listView;
MyAdapter myAdapter;
ArrayList<Record>arrayList;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_home);
    Name=(TextView)findViewById(R.id.Name);
    addlead=(Button)findViewById(R.id.addlead);
    refresh=(Button)findViewById(R.id.viewlead);
    listView=(ListView)findViewById(R.id.list_view);
    sqLiteOpenHelper=new DatabaseHelper(this);
    db=sqLiteOpenHelper.getReadableDatabase();
    databaseHelper=new DatabaseHelper(this);
    arrayList=new ArrayList<>();
    loaddatainlist();
    registerForContextMenu(listView);

    Name.setText(getIntent().getStringExtra(MainActivity.user));
    refresh();
   add_lead();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.menu, menu);
    return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
    int id = item.getItemId();

    if (id == R.id.mybutton) {
        AlertDialog.Builder builder=new AlertDialog.Builder(this);
        builder.setMessage("Are you really want to Logout ?")
                .setCancelable(false)
                .setPositiveButton("Yes", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        Toast.makeText(getApplicationContext(),"Logout Successfully",Toast.LENGTH_SHORT).show();
                        finish();
                        //startActivity(new Intent(Home.this,MainActivity.class));
                    }
                })
                .setNegativeButton("No", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dialog.cancel();
                    }
                });
        AlertDialog alertDialog=builder.create();
        alertDialog.show();

    }
    return super.onOptionsItemSelected(item);
}


public void add_lead()
{
    addlead.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
         startActivity(new Intent(Home.this,Registration.class));
        }
    });
}

  private void loaddatainlist()
  {
      arrayList=databaseHelper.getalldata();
     myAdapter=new MyAdapter(this,arrayList);
     listView.setAdapter(myAdapter);
     myAdapter.notifyDataSetChanged();

  }

@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
    super.onCreateContextMenu(menu, v, menuInfo);
    getMenuInflater().inflate(R.menu.listoption,menu);
}

@Override
public boolean onContextItemSelected(MenuItem item) {
    switch (item.getItemId())
    {
        case R.id.editoption:
            {
            startActivity(new Intent(Home.this, Update.class));
        }
        case R.id.deleteoption:
            {
            Toast.makeText(this, "Delete", Toast.LENGTH_SHORT).show();
        }

       return true;
       default:
           return super.onContextItemSelected(item);
    }

}
public void refresh()
{
    refresh.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            finish();
            startActivity(getIntent());
        }
    });
}

}

公共类更新扩展 AppCompatActivity {

EditText lead,name,company,mobile,address;
Button update;
DatabaseHelper databaseHelper;
SQLiteDatabase dataBase;
ImageButton getrecord;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_update);
    databaseHelper=new DatabaseHelper(this);

    lead=(EditText)findViewById(R.id.lead);
    name=(EditText)findViewById(R.id.updatename);
    company=(EditText)findViewById(R.id.updatecompany_name);
    address=(EditText)findViewById(R.id.updateaddress);
    mobile=(EditText)findViewById(R.id.updatemobile);
    update=(Button)findViewById(R.id.update_button);

}
 }

我显示了我存储在数据库中的所有记录,但我无法更新它。

【问题讨论】:

  • 我正在尝试分享代码,但在我发布时它给出了一些错误。
  • 您好,我发布了代码,您可以检查一下吗。
  • 您能否告诉我们您面临或无法实施的确切问题是什么?
  • 如果您通过提及您在上述代码 sn-ps 中使用的 UI 组件来详细说明您的要求,那也很好。
  • 当我长按列表的任何一行时,我创建了两个选项更新和删除,当我点击更新时,它将继续另一个更新的活动,这里我想要这一行的所有值我保存在数据库中将在更新任何特定行后预填充。

标签: java android sqlite


【解决方案1】:

我会一个接一个地上课,让事情变得容易理解。

DatabaseHelper 类: 我不确定您为什么在 onCreate() 方法中使用了以下部分:

如果没有特定用途,则可以将其删除(您可以评论它的用途)。

现在使用您在 Client 表中使用的所有字段来完成您的 Record 模型。如果不是,也使类序列化。所以 Record 类看起来像-

public class Record implements Serializable {
    ..
    public Record(String sno, lead, String name, String mobile, String companyName, ...) {
        this.sno = sno;
        this.lead = lead;
        this.name = name;
        this.mobile = mobile;
        this.companyName = companyName;
        .
        .
        .
    }
    ..
}

回到 db 类。 update()方法改为-

public boolean updateClientInfo(Record record) {
    SQLiteDatabase sqLiteDatabase = this.getWritableDatabase();
    //Updated code will be like
    ContentValues contentValues = new ContentValues();
    contentValues.put(Column21, record.getLead());
    .
    .
    .
    int count = sqLiteDatabase.update(Table2, contentValues, "SNO = ?", new String[] {record.getSno()});

    return count > 0 ? true : false;
}

getAllData()方法中填充Record模型列表,在更新的Record模型中填充所有字段,例如SNO等(如上所述,添加字段)。

delete()方法的代码改为-

public boolean deleteClientInfo(Record record) {
    SQLiteDatabase sqLiteDatabase = this.getWritableDatabase();

    //Updated code will be
    int count = sqLiteDatabase.update(Table2, "SNO = ?", new String[] {record.getSno()});

    return count > 0 ? true : false;
}   

将 DB 类中的 getalldata() 方法更新为 -

我已经更新了您的 Home 活动类,以便它可以完美地用于数据库刷新。您尝试主要注意以下区域的差异-

refresh() -> 更新,loaddatainlist() -> 移除,createAdapter() -> 添加,refreshListFromDb() -> 添加,onCreate() 更新,onReume() -> 添加。

public class Home extends AppCompatActivity {

    TextView Name;
    Button refresh, addlead;
    DatabaseHelper databaseHelper;
    SQLiteOpenHelper sqLiteOpenHelper;
    SQLiteDatabase db;
    ListView listView;
    MyAdapter myAdapter;
    ArrayList<Record> arrayList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_home);
        Name = (TextView) findViewById(R.id.Name);
        addlead = (Button) findViewById(R.id.addlead);
        refresh = (Button) findViewById(R.id.viewlead);
        listView = (ListView) findViewById(R.id.list_view);
        sqLiteOpenHelper = new DatabaseHelper(this);
        db = sqLiteOpenHelper.getReadableDatabase();
        databaseHelper = new DatabaseHelper(this);
        arrayList = new ArrayList<>();
        createAdapter();
        registerForContextMenu(listView);

        Name.setText(getIntent().getStringExtra(MainActivity.user));
        refresh();
        add_lead();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu, menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        int id = item.getItemId();

        if (id == R.id.mybutton) {
            AlertDialog.Builder builder = new AlertDialog.Builder(this);
            builder.setMessage("Are you really want to Logout ?").setCancelable(false)
                    .setPositiveButton("Yes", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            Toast.makeText(getApplicationContext(), "Logout Successfully", Toast.LENGTH_SHORT).show();
                            finish();
                            // startActivity(new Intent(Home.this,MainActivity.class));
                        }
                    }).setNegativeButton("No", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            dialog.cancel();
                        }
                    });
            AlertDialog alertDialog = builder.create();
            alertDialog.show();

        }
        return super.onOptionsItemSelected(item);
    }

    public void add_lead() {
        addlead.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                startActivity(new Intent(Home.this, Registration.class));
            }
        });
    }

    private void createAdapter() {
        myAdapter = new MyAdapter(this, arrayList);
        listView.setAdapter(myAdapter);
    }

    private void refreshListFromDb() {
        arrayList = databaseHelper.getAllClientData(arrayList);
        myAdapter.notifyDataSetChanged();

    }

    @Override
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        super.onCreateContextMenu(menu, v, menuInfo);
        getMenuInflater().inflate(R.menu.listoption, menu);
    }

    @Override
    public boolean onContextItemSelected(MenuItem item) {
        switch (item.getItemId()) {
        case R.id.editoption: {
            startActivity(new Intent(Home.this, Update.class));
        }
        case R.id.deleteoption: {
            Toast.makeText(this, "Delete", Toast.LENGTH_SHORT).show();
        }

            return true;
        default:
            return super.onContextItemSelected(item);
        }

    }

    public void refresh() {
        refresh.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                refreshListFromDb();
            }
        });
    }

    @Override
        public void onResume() {
            super.onResume();
            refreshListFromDb()
        }
}

When you are calling Update class after longpress call the Intent as-

Intent intent = new Intent(this, Update.class);
intent.putExtra("parcel_record", recordModel); // record model of the index from array list where longpress is made. 
startActivity(intent);

像这样在更新活动中获取记录对象-

@Override
protected void onCreate(Bundle savedInstanceState) {
    // Using getParcelableExtra(String key) method
    Record record = (Record) getIntent().getParcelableExtra("parcel_record");
    ....
}

现在通过从记录模型中获取更新活动中的名称、移动设备等字段,例如

editTextMobile.setText(record.getMobile());

一旦用户单击更新按钮,使用字段中的编辑值更新记录模型,例如 -

record.setMobile(editTextMobile.getText().toString());
....

并调用 DB 助手类的 updateClientInfo(record)

希望详细信息能帮助您满足您的要求。

注意:这是我的建议,为变量和方法使用适当的名称,例如 DB 类中的 getingData() 到 getUserRecord(),insertData() 到 insertClientInfo() 等等。

【讨论】:

  • 先生,实际上这个触发器是根据我的指导方向实施的。我的指南给了我一些设计示例,这就是为什么我需要使用触发器两列。
  • 没关系,请按照上面的详细信息,如果您在实施时遇到任何问题,请告诉我。
  • 我已经更新了我的回答者并添加了获得结果所需的所有必要细节。还有一件事,对于删除,从 DB 类调用 delete 方法,然后在 Home 活动中调用 refreshListFromDb() 方法。它会自动刷新列表。
  • 先生,我不明白什么是唱片模型。
  • 还有一个问题先生,如果我们有多个列表视图都有不同的记录并且所有记录都从不同的表中获取,那么对于每个列表视图需要为每个列表视图创建特定的模型类和特定的适配器类?
【解决方案2】:

试试这个:-

lv.setOnItemLongClickListener(new OnItemLongClickListener() {
            @Override
            public boolean onItemLongClick(AdapterView<?> arg0, View arg1,
                    int pos, long id) {
                // TODO Auto-generated method stub

                Log.v("long clicked","pos: " + pos);

                return true;
            }
        }); 

如果你想在适配器项上设置onLongClick。那么就这样做**(在适配器的onBindViewHolder方法中)**:-

    holder.lv.setOnItemLongClickListener(new OnItemLongClickListener() {

        //your code here.i.e updating the database

    }

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-12-30
    • 2016-05-04
    • 2021-08-27
    • 1970-01-01
    • 2019-08-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多