上传文件到数据库中,ListView实时查询数据库(实时刷新数据)

本文介绍如何使用Bmob进行文件上传,并通过实时更新ListView来展示上传状态及文件信息,采用SResourceBean实体类存储文件数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说是实时其实是投机取巧了,用的就是适配器的notifyDataSetChanged功能,下面就直接说了。我用的是Bmob的服务器,但道理是一样的。

1、ListView要显示的数据的实体类

public class SResourceBean {
    private String time;        //上传时间
    private String size;        //文件大小
    private String fileName;    //文件名称
    private String urlName;     //文件路径

    public SResourceBean(String time, String size, String fileName, String urlName) {
        this.time = time;
        this.size = size;
        this.fileName = fileName;
        this.urlName = urlName;
    }

    public String getTime() {
        return time;
    }

    public String getSize() {
        return size;
    }

    public String getFileName() {
        return fileName;
    }

    public String getUrlName() {
        return urlName;
    }
}

2、Bomb的上传文件方法(showUtils只是我写的一个Toast的类而已)

注:重点是实时刷新界面,数据是临时数据,但再次进去时就是从数据库获取的数据了。只要临时数据和数据库数据一致即可,看起来是一样的。下面的方法涉及的其他类不做介绍。

private ArrayList<SResourceBean> data = new ArrayList<>();
private void uploadFile(final String path) {
        final BmobFile bmobFile = new BmobFile(new File(path));
        bmobFile.uploadblock(new UploadFileListener() {

            @Override
            public void done(BmobException e) {
                if(e==null){
                    SResource resource = new SResource();

                    Student student = new Student();
                    student.setObjectId(studentId);

                    FileSizeUtil fileSizeUtil = new FileSizeUtil();
                    final String size = fileSizeUtil.getAutoFileOrFilesSize(path);

                    resource.setStudent(student);
                    resource.setTitle(bmobFile);
                    resource.setSize(size);
                    resource.save(new SaveListener<String>() {
                        @Override
                        public void done(String s, BmobException e) {
                            if (e == null) {
                                showUtils.show(context, "上传成功至数据库");
                                
                                //关键代码
                                String name = bmobFile.getFilename();
                                String url = bmobFile.getFileUrl();

                                data.add(new SResourceBean("当前", size, name, url));
                                adapter.notifyDataSetChanged();
                                //关键代码 以上是给adapter提示说listview的数据已经更改成了这样,这是临时数据。
                                //        下次再进入界面时,数据就是从数据库获取真实数据了。
                                
                             } else {
                                showUtils.show(context, "文件上传至数据库失败:" + e.getErrorCode() + "," + e.getMessage());
                            }
                        }
                    });
                }else{
                    showUtils.show(context, "上传失败"+e.getErrorCode()+","+e.getMessage());
                }
            }

            @Override
            public void onProgress(Integer value) {
                // 返回的上传进度(百分比)
                showUtils.show(context, "文件上传中……"+value+"%");
            }
        });


在C#中,可以使用以下步骤来实时刷新ListView中的数据: 1. 绑定数据源:将数据库中的数据绑定到ListView控件上,可以使用以下代码: ```csharp listView1.View = View.Details; listView1.GridLines = true; listView1.FullRowSelect = true; //连接数据库 string connString = "server=localhost;database=myDatabase;uid=root;pwd=myPassword;"; MySqlConnection conn = new MySqlConnection(connString); conn.Open(); //查询数据库 string query = "SELECT * FROM myTable"; MySqlCommand cmd = new MySqlCommand(query, conn); MySqlDataReader reader = cmd.ExecuteReader(); //添加数据ListView while (reader.Read()) { ListViewItem item = new ListViewItem(reader["column1"].ToString()); item.SubItems.Add(reader["column2"].ToString()); item.SubItems.Add(reader["column3"].ToString()); listView1.Items.Add(item); } //关闭连接 reader.Close(); conn.Close(); ``` 2. 实时刷新数据:可以使用定时器来定期查询数据库,并更新ListView中的数据。以下是示例代码: ```csharp private Timer timer1; public Form1() { InitializeComponent(); //创建定时器 timer1 = new Timer(); timer1.Interval = 5000; //5秒钟刷新一次 timer1.Tick += new EventHandler(timer1_Tick); timer1.Start(); } private void timer1_Tick(object sender, EventArgs e) { //清空ListView中的数据 listView1.Items.Clear(); //连接数据库 string connString = "server=localhost;database=myDatabase;uid=root;pwd=myPassword;"; MySqlConnection conn = new MySqlConnection(connString); conn.Open(); //查询数据库 string query = "SELECT * FROM myTable"; MySqlCommand cmd = new MySqlCommand(query, conn); MySqlDataReader reader = cmd.ExecuteReader(); //添加数据ListView while (reader.Read()) { ListViewItem item = new ListViewItem(reader["column1"].ToString()); item.SubItems.Add(reader["column2"].ToString()); item.SubItems.Add(reader["column3"].ToString()); listView1.Items.Add(item); } //关闭连接 reader.Close(); conn.Close(); } ``` 在这个示例中,我们创建了一个定时器,每5秒钟查询一次数据库,并更新ListView控件中的数据。当需要实时更新ListView数据时,只需要调整定时器的间隔即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值