值总是返回0,它应返回插入的行数

时间:2015-12-30 17:21:50

标签: php android mysql return toast

我有两个表,一个是Information,另一个是WorkForce

信息

enter image description here

劳动力

enter image description here

WorkForce 中的twf column用于获取信息id,假设返回为1,但返回值为0 。如果信息中的id 5,则twf也应为5。

首先,我使用a来表示所选行的数量,然后将a的参数添加到addWorkForce中。 toast始终显示0。

  a=addInformation(name,weather,date2,status,first1[1],last1[1]);
  Toast.makeText(getApplicationContext(),a+"",Toast.LENGTH_LONG).show();
  addWorkForce(Sub, NoP, NoH,a);

添加信息功能

  public long addInformation( final String name, final String weather, final String date2, final String status, final String timeIn, final String timeOut)
    {
        class AddInfo extends AsyncTask<String, Void, String> {
            ProgressDialog loading;

            @Override
            protected void onPreExecute() {
                super.onPreExecute();
                loading = ProgressDialog.show(WorkDetailsTable.this, "Please Wait",null, true, true);
            }

            @Override
            protected void onPostExecute(String s) {
                super.onPostExecute(s);
                loading.dismiss();
                Toast.makeText(getApplicationContext(),s,Toast.LENGTH_LONG).show();
            }

            @Override
            protected String doInBackground(String... params) {

                HashMap<String, String> data = new HashMap<String,String>();
                data.put(Config.KEY_USER_NAME,name);
                data.put(Config.KEY_WEATHER,weather);
                data.put(Config.KEY_DATE,date2);
                data.put(Config.KEY_STATUS,status);
                data.put(Config.KEY_TIMEIN,timeIn);
                data.put(Config.KEY_TIMEOUT,timeOut);
                RequestHandler rh=new RequestHandler();
                String result = rh.sendPostRequest(Config.ADD_INFORMATION,data);
                return  result;
            }
        }

         AddInfo ru = new AddInfo();
         ru.execute(name,weather,date2,status,timeIn,timeOut);

        return 0;

    }

有人可以帮我解决问题吗?

addInformation.php

<?php 

    if($_SERVER['REQUEST_METHOD']=='POST'){

        //Getting values
        $name = $_POST['name'];
        $weather = $_POST['weather'];
        $date = $_POST['date'];
                $status = $_POST['status'];
                $timeIn = $_POST['timeIn'];
                $timeOut = $_POST['timeOut'];

        //Creating an sql query
        $sql = "INSERT INTO information(name, weather, date, status, time_in, time_out) VALUES ('$name','$weather','$date', '$status', '$timeIn', '$timeOut')";

        //Importing our db connection script
        require_once('dbConnect.php');

        //Executing query to database
        if(mysqli_query($con,$sql)){
            echo 'Information Added Successfully';
        }else{
            echo 'Could Not Add Information';
        }

        //Closing the database 
        mysqli_close($con);
    }
?>

这是我使用代码将行插入sqlite的方法,它可以正常工作

 a = ts.insertTimeSheet(name, weather, date2, status, first1[1], last1[1]);

的TimeSheet

 public long insertTimeSheet(String name, String weather, String date, String status, String TimeIn, String TimeOut) {
        database = dbHelper.getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(MyDatabaseHelper.Name, name);
        values.put(MyDatabaseHelper.Weather, weather);
        values.put(MyDatabaseHelper.Date, date);
        values.put(MyDatabaseHelper.Status, status);
        values.put(MyDatabaseHelper.TimeIn_Info, TimeIn);
        values.put(MyDatabaseHelper.TimeOut_Info, TimeOut);
        return database.insert(MyDatabaseHelper.TABLE_INFO, null, values); // if the id in Information is 5, twf display 5 too

4 个答案:

答案 0 :(得分:7)

根据您的代码添加信息:

a=addInformation(name,weather,date2,status,first1[1],last1[1]);

在这里,您在主线程上调用addInformation并将返回值保存到变量a。但问题是,您添加信息的实际实现是在doInBackground AsyncTask中完成的,它实际上在工作线程上执行了工作(异步调用),因此您将始终获得a =的默认值0(很长)。

您需要做的是将代码移至onPostExecute AsyncTask函数,如下所示:

public void addInformation( final String name, final String weather, final String date2, final String status, final String timeIn, final String timeOut)
    {
        class AddInfo extends AsyncTask<String, Void, String> {
            ProgressDialog loading;

            @Override
            protected void onPreExecute() {
                super.onPreExecute();
                loading = ProgressDialog.show(WorkDetailsTable.this, "Please Wait",null, true, true);
            }

            @Override
            protected void onPostExecute(String s) {
                super.onPostExecute(s);
                loading.dismiss();
                Toast.makeText(getApplicationContext(),s,Toast.LENGTH_LONG).show();
                addWorkForce(Sub, NoP, NoH,a);
            }

            @Override
            protected String doInBackground(String... params) {

                HashMap<String, String> data = new HashMap<String,String>();
                data.put(Config.KEY_USER_NAME,name);
                data.put(Config.KEY_WEATHER,weather);
                data.put(Config.KEY_DATE,date2);
                data.put(Config.KEY_STATUS,status);
                data.put(Config.KEY_TIMEIN,timeIn);
                data.put(Config.KEY_TIMEOUT,timeOut);
                RequestHandler rh=new RequestHandler();
                String result = rh.sendPostRequest(Config.ADD_INFORMATION,data);
                return  result;
            }
        }

         AddInfo ru = new AddInfo();
         ru.execute(name,weather,date2,status,timeIn,timeOut);

    }

还有另一种使用回调的方法。实现一个接口,在完成AsyncTask之后,你可以发送回调来做另一个工作。

答案 1 :(得分:4)

我认为问题来自这一行

return 0;

您的addInformation方法每次返回一个值为0的long。如果您希望它返回其他一些数字,则需要更改该行。

编辑: 要跟踪您的行,请在方法标题中添加另一个参数

public long addInformation(int rowId, final String name, final String weather, final String date2, final String status, final String timeIn, final String timeOut)

答案 2 :(得分:4)

在第一个表中插入行之后可以使用lastInsertId()mysql函数。这是(信息) 将lastInsertId()的值存储在某个变量中,并在下一个表中插入行时使用该变量。那是(WorkForce)

答案 3 :(得分:4)

由于AsyncTask是异步任务,因此return 0;方法中的addInformation行始终排在第一位,这就是 0 而不是的原因“插入的行数”

您应该按以下方式更新您的代码,请注意我的评论// MOVE addWorkForce HERE

public void addInformation( final String name, final String weather, final String date2, final String status, final String timeIn, final String timeOut)
{
    class AddInfo extends AsyncTask<String, Void, String> {
        ProgressDialog loading;

        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            loading = ProgressDialog.show(WorkDetailsTable.this, "Please Wait",null, true, true);
        }

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
            loading.dismiss();
            Toast.makeText(getApplicationContext(),s,Toast.LENGTH_LONG).show();
            addWorkForce(Sub, NoP, NoH, Long.parseLong(s)); // MOVE addWorkForce HERE
        }

        @Override
        protected String doInBackground(String... params) {

            HashMap<String, String> data = new HashMap<String,String>();
            data.put(Config.KEY_USER_NAME,name);
            data.put(Config.KEY_WEATHER,weather);
            data.put(Config.KEY_DATE,date2);
            data.put(Config.KEY_STATUS,status);
            data.put(Config.KEY_TIMEIN,timeIn);
            data.put(Config.KEY_TIMEOUT,timeOut);
            RequestHandler rh=new RequestHandler();
            String result = rh.sendPostRequest(Config.ADD_INFORMATION,data);
            return  result;
        }
    }

     AddInfo ru = new AddInfo();
     ru.execute(name,weather,date2,status,timeIn,timeOut);  
}

然后,你只需要打电话

addInformation(name,weather,date2,status,first1[1],last1[1]);

当然,请确保Sub, NoP, NoH类中可以访问AddInfo个变量。

希望它有所帮助!