Я не могу использовать логическое значение как целое число - PullRequest
0 голосов
/ 29 мая 2018

Почему это не работает?У меня проблема с базой данных.Как логическое использование в качестве int?Может быть, я написал плохой код. Я использовал булево как целое, верно?Как сделать вставку в базу данных. Как сохранить значение логического значения из флажка в базе данных?

Мой код базы данных в Android

public class DataBase extends SQLiteOpenHelper{
    public static final String DATABASE_NAME = "DataOfSchedule.db";
    public static final String TABLE_NAME = "DataOfSchedule_table";
    public static final String COL_ID = "ID";
    public static final String COL_NAME = "NAME";
    public static final String COL_AGE = "AGE";
    public static final String COL_GENDER_M = "GENDER_M";
    public static final String COL_GENDER_F = "GENDER_F";
    public static final String COL_WEIGHT = "WEIGHT";
    public static final String COL_HEIGHT = "HEIGHT";
    public static final String COL_TRAUMA = "TRAUMA";
    public DataBase(Context context){
        super(context, DATABASE_NAME, null,1);
    }
    @Override
    public void onCreate(SQLiteDatabase db){
        db.execSQL("CREATE TABLE" + TABLE_NAME +
                COL_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                COL_NAME + " TEXT," +
                COL_AGE + " INTEGER NOT NULL DEFAULT 0, " +
                COL_GENDER_M + " INTEGER NOT NULL DEFAULT 0, " +
                COL_GENDER_F + " INTEGER NOT NULL DEFAULT 0, " +
                COL_TRAUMA + " INTEGER NOT NULL DEFAULT 0, " +
                COL_WEIGHT + " INTEGER NOT NULL DEFAULT 0, " +
                COL_HEIGHT + " INTEGER NOT NULL DEFAULT 0);");
    }
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){
        db.execSQL("DROP TABLE IF EXISTS" + TABLE_NAME);
    }
    //  public boolean insertData(String name, Integer age, Integer sex_male, Integer sex_female, Integer weight, Integer height, Integer trauma){
    //    SQLiteDatabase db = this.getWritableDatabase();
    //    ContentValues contentValues = new ContentValues();
        public boolean insertData(String name, Integer age, Integer gender_m, Integer gender_f, Integer weight, Integer height, Integer trauma){
            boolean success = false;
            try{
                SQLiteDatabase db = this.getWritableDatabase();
                ContentValues contentValues = new ContentValues();
                contentValues.put(COL_NAME, name);
                contentValues.put(COL_AGE, age);
                contentValues.put(COL_GENDER_M, gender_m);
                contentValues.put(COL_GENDER_F, gender_f);
                contentValues.put(COL_WEIGHT, weight);
                contentValues.put(COL_HEIGHT, height);
                contentValues.put(COL_TRAUMA, trauma);
                long result = db.insert(TABLE_NAME,null,contentValues);
                db.close();

                if(result != -1) success = true;
            }
            catch(Exception ex){

            }

            return success;
        }

    public Cursor getALLData(){
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor res = db.rawQuery("Select * from "+ TABLE_NAME,null);
        return res;
    }
}

Моя основная_активность

public class InsertData extends AppCompatActivity {
    DataBase myDb;
    EditText txtName, txtAge , txtWeight, txtHeight;
    CheckBox boxGender_m,boxGender_f,boxTrauma;
    Button btnClick;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_insert_data);
        myDb = new DataBase(this);
        txtName = (EditText) findViewById(R.id.name);
        txtAge = (EditText) findViewById(R.id.age);
        boxGender_m = (CheckBox) findViewById(R.id.gender_m);
        boxGender_f = (CheckBox) findViewById(R.id.gender_f);
        boxTrauma = (CheckBox) findViewById(R.id.trauma);
        txtWeight = (EditText) findViewById(R.id.weight);
        txtHeight = (EditText) findViewById(R.id.height);
        btnClick = (Button) findViewById(R.id.InsertBtn);
        btnClick.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v){
                ClickMe();
            }
        });
    }

    private void ClickMe(){
        String name = txtName.getText().toString();
        String age = txtAge.getText().toString();
        String gender_m = boxGender_m.getText().toString();
        String gender_f = boxGender_f.getText().toString();
        String trauma = boxTrauma.getText().toString();
        String weight = txtName.getText().toString();
        String height = txtName.getText().toString();
        int gender_int_m = Integer.parseInt(gender_m);
        int gender_int_f = Integer.parseInt(gender_f);
        int trauma_int = Integer.parseInt(trauma);
        int weight_int = Integer.parseInt(weight);
        int age_int = Integer.parseInt(age);
        int height_int = Integer.parseInt(height);
        Boolean result = myDb.insertData( name, age_int, gender_int_m, gender_int_f, weight_int, height_int, trauma_int);
        if (result == true){
            Toast.makeText(this, "Data Inserted Successfully",Toast.LENGTH_SHORT).show();
        }else{
            Toast.makeText(this, "Data Inserted Failed",Toast.LENGTH_SHORT).show();
        }
        Intent i = new Intent(this,ResultData.class);
        startActivity(i);
    }

}

В чем дело?Мой XML

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="16dp"
    tools:context="daniel_nikulshyn_and_andrew_rybka.myway.InsertData">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:layout_alignParentTop="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true">
    <TextView
        android:id="@+id/heading"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/insert_heading"
        android:layout_gravity="center"
        android:textSize="16dp"
        android:textColor="#021aee"/>

    <EditText
        android:id="@+id/name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/insert_name"/>
    <EditText
        android:id="@+id/age"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/insert_age"
        android:numeric="integer"/>
    <EditText
        android:id="@+id/weight"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/insert_weight"
        android:numeric="integer"/>
    <EditText
        android:id="@+id/height"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/insert_height"
        android:numeric="integer"/>

    <TextView
        android:padding="10dp"
        android:text="@string/insert_gender"
        android:layout_gravity="left"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <CheckBox
        android:id="@+id/gender_m"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/male"/>
    <CheckBox
        android:id="@+id/gender_f"
        android:text="@string/female"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <TextView
        android:padding="10dp"
        android:text="@string/insert_trauma"
        android:layout_gravity="left"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <CheckBox
        android:id="@+id/trauma"
        android:text="@string/insert_trauma_subtitle"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="20dp"/>

    <Button
        android:id="@+id/InsertBtn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@color/colorPrimary"
        android:text="@string/insert_button"
        android:textColor="#f2fde4"
        android:layout_gravity="center"/>
</LinearLayout>

</ScrollView>

В чем дело?Приложение закрывается, когда я нажимаю btn «Хорошо» с идентификатором InsertBtn

Ответы [ 2 ]

0 голосов
/ 30 мая 2018

Короче говоря, вы должны использовать метод isChecked, чтобы узнать, установлен ли флажок checkBox, который будет логическим.

Я не уверен точно, что вернет getText(), но это, скорее всего, не будет строка, которую можно было бы проанализировать в int, поэтому при попытке анализа вы получите исключение. В качестве аналогии можно сказать, что вы платите мне $ rumplestiltskin.Сколько вы мне дадите?

Таким образом, ваш код может выглядеть следующим образом: -

private void ClickMe(){


    String name = txtName.getText().toString();
    String age = txtAge.getText().toString();
    //String gender_m = boxGender_m.getText().toString(); //<<<< WRONG
    //String gender_f = boxGender_f.getText().toString(); //<<<< WRONG
    String trauma = boxTrauma.getText().toString();
    String weight = txtName.getText().toString();
    String height = txtName.getText().toString();
    //<<<<<<<<<< ADDED CODE >>>>>>>>>>
    int gender_int_m = 0;
    if (boxGender_m.isChecked()) {
        gender_int_m = 1;
    }
    int gender_int_f = 0;
    if (boxGender_f.isChecked()) {
        gender_int_f = 1;
    }
    //int gender_int_m = Integer.parseInt(gender_m); //<<<< REDUNDANT
    //int gender_int_f = Integer.parseInt(gender_f); //<<<< REDUNDANT
    int trauma_int = Integer.parseInt(trauma);
    int weight_int = Integer.parseInt(weight);
    int age_int = Integer.parseInt(age);
    int height_int = Integer.parseInt(height);
    Boolean result = myDb.insertData( name, age_int, gender_int_m, gender_int_f, weight_int, height_int, trauma_int);
    if (result == true){
        Toast.makeText(this, "Data Inserted Successfully",Toast.LENGTH_SHORT).show();
    }else{
        Toast.makeText(this, "Data Inserted Failed",Toast.LENGTH_SHORT).show();
    }
    Intent i = new Intent(this,ResultData.class);
    startActivity(i);
}}
0 голосов
/ 29 мая 2018

Вы устанавливаете эти значения:

 int gender_int_m = Integer.parseInt(gender_m);
 int gender_int_f = Integer.parseInt(gender_f);
 int trauma_int = Integer.parseInt(trauma);
 int weight_int = Integer.parseInt(weight);
 int age_int = Integer.parseInt(age);
 int height_int = Integer.parseInt(height);

... в качестве примитива int, но метод insertData принимает объект Integer в качестве аргументов:

public boolean insertData(String name, Integer age, Integer gender_m, Integer gender_f, 
                          Integer weight, Integer height, Integer trauma){...

В Java int и Integer - это НЕ одно и то же.Я предлагаю вам обновить insertData, чтобы принять примитив int в качестве аргументов:

public boolean insertData(String name, int age, int gender_m, int gender_f, 
                          int weight, int height, int trauma){...
...