Как вставить в базу данных sqlite значения полей динамического редактирования текста - PullRequest
0 голосов
/ 10 октября 2018

Я хочу вставить номера мобильных телефонов в свою базу данных SQLite, а значения - в мои поля edittext.Текст редактирования создается динамически после нажатия кнопки, как показано на скриншоте.Пользователь может добавить несколько номеров.В настоящее время мой код добавляет только одну цифру в моей таблице базы данных.Пожалуйста, смотрите мои коды ниже

Основной код макета:

        <EditText
            android:id="@+id/editNumber"
            android:layout_width="300dp"
            android:layout_height="wrap_content"
            android:ems="10"
            android:hint="Mobile Number"
            android:inputType="number"
            android:layout_gravity="center"/>

        <Button
            android:id="@+id/btnNumber"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:drawableLeft="@android:drawable/ic_input_add"
            android:text="Add Number"
            android:layout_gravity="center"
            android:onClick="onAddField"/>

Динамическое добавление номера Код макета:

<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="50dp"
android:orientation="horizontal">

<EditText
    android:id="@+id/editNumber"
    android:layout_width="260dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="8dp"
    android:layout_marginStart="32dp"
    android:layout_marginTop="8dp"
    android:ems="10"
    android:hint="Mobile Number"
    android:inputType="number" />
<Button
    android:id="@+id/delete_button"
    android:layout_width="0dp"
    android:layout_height="40dp"
    android:layout_weight="1"
    android:layout_marginEnd="8dp"
    android:layout_marginStart="8dp"
    android:layout_marginTop="8dp"
    android:background="@android:drawable/ic_delete"
    android:onClick="onDelete"/>

</LinearLayout>

.java код динамического добавления eddittext

public void onAddField(View v) {
    LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    final View rowView = inflater.inflate(R.layout.field, null);
    parentLinearLayout.addView(rowView, parentLinearLayout.getChildCount() - 1);
}

public void onDelete(View v) {
    parentLinearLayout.removeView((View) v.getParent());
}

Ссылка в моем коде динамического добавления и удаления текста редактирования: эта ссылка.

Вот мой код вставки значений в базу данных

if (editNumber.length() != 0) {
            boolean isInserted = myDB.addData(editNumber.getText().toString(),

            if (isInserted == true) {
                Toast.makeText(this, "Successfully added!", Toast.LENGTH_SHORT).show();
            } else {
                Toast.makeText(this, "Something went wrong, please try again.", Toast.LENGTH_SHORT).show();
            }
        } else {
            Toast.makeText(this, "All fields are required.", Toast.LENGTH_SHORT).show();
        }

DatabaseHelperaddData

public boolean addData(String number){
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues contentValues = new ContentValues();
    contentValues.put(COL1, number);
    long result = db.insert(TABLE_NAME,null,contentValues);

    if(result == -1){
        return false;
    }else {
        return true;
    }
}

Image 1

1 Ответ

0 голосов
/ 10 октября 2018

Вы можете рассмотреть возможность создания цикла для этого, например:

private void addAll()
{
    for(int i=0;i<parentLinearLayout.getChildCount();i++)
        {
            EditText ediNumber=(EditText)parentLinearLayout.getChildAt(i);

           if (editNumber.getText().toString().trim().length() != 0) {
            boolean isInserted = myDB.addData(editNumber.getText().toString(),

            if (isInserted == true) {
                Toast.makeText(this, "Successfully added!", Toast.LENGTH_SHORT).show();
            } else {
                Toast.makeText(this, "Something went wrong, please try again.", Toast.LENGTH_SHORT).show();
            }
        } else {
            Toast.makeText(this, "All fields are required.", Toast.LENGTH_SHORT).show();
        }
        }
}

Попробуйте это и дать отзыв

...