మెనూ
in ,

లారావెల్‌లోని డేటాబేస్‌లో బహుళ చెక్‌బాక్స్ విలువలను ఎలా నిల్వ చేయాలి?

నేను లారావెల్‌లోని డేటాబేస్‌లో చెక్‌బాక్స్ విలువలను నిల్వ చేయాలి. ఎలా చెయ్యాలి ?

లారావెల్‌లోని డేటాబేస్‌లో బహుళ చెక్‌బాక్స్ విలువలను ఎలా నిల్వ చేయాలి?

లారావెల్‌లోని డేటాబేస్‌లో బహుళ చెక్‌బాక్స్‌ల విలువలను నిల్వ చేయడానికి అనేక మార్గాలు ఉన్నాయి. ఇక్కడ కొన్ని ఎంపికలు ఉన్నాయి:

  1. "బూలియన్" రకం ఫీల్డ్‌ని ఉపయోగించండి : ప్రతి చెక్‌బాక్స్ మీ డేటాబేస్‌లోని బూలియన్ టైప్ ఫీల్డ్‌లో "నిజం" లేదా "తప్పు"గా సేవ్ చేయబడుతుంది.
  2. "టెక్స్ట్" టైప్ ఫీల్డ్‌ని ఉపయోగించండి : మీరు అన్ని చెక్‌బాక్స్‌ల విలువలను టెక్స్ట్ టైప్ ఫీల్డ్‌లో నిల్వ చేయవచ్చు, ప్రతి విలువను కామాతో వేరు చేస్తుంది. ఉదాహరణకు, వినియోగదారు "పండ్లు" మరియు "కూరగాయలు" పెట్టెలను తనిఖీ చేసినట్లయితే, మీరు ఈ సమాచారాన్ని టెక్స్ట్ టైప్ ఫీల్డ్‌లో "పండ్లు, కూరగాయలు"గా సేవ్ చేయవచ్చు.
  3. సంబంధాల పట్టికను ఉపయోగించండి : మీరు ఒకే రికార్డ్‌కి లింక్ చేయబడిన అనేక చెక్‌బాక్స్‌లను కలిగి ఉంటే, మీరు ఈ డేటాను నిల్వ చేయడానికి రిలేషన్ టేబుల్‌ని ఉపయోగించవచ్చు. ఉదాహరణకు, మీరు "కేటగిరీలు" నిలువు వరుసతో "ఉత్పత్తుల" పట్టికను కలిగి ఉంటే, మీరు ఎంచుకున్న వర్గాలను ప్రతి ఉత్పత్తికి లింక్ చేసే "ఉత్పత్తి_వర్గాలు" పట్టికను సృష్టించవచ్చు.
  4. "టేబుల్" రకం ఫీల్డ్‌ను ఉపయోగించండి : మీరు శ్రేణులకు (PostgreSQL వంటి) మద్దతు ఇచ్చే డేటాబేస్‌ని ఉపయోగిస్తుంటే, మీరు శ్రేణి రకం ఫీల్డ్‌లో బహుళ చెక్‌బాక్స్‌ల విలువలను నిల్వ చేయవచ్చు. ఇది రిలేషన్ షిప్ టేబుల్‌ని ఉపయోగించకుండా ఒకే ఫీల్డ్‌లో బహుళ విలువలను నిల్వ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది.

శ్రేణిని ఉపయోగించి బహుళ చెక్‌బాక్స్ విలువలను డేటాబేస్‌లో నిల్వ చేయండి

లారావెల్‌లో, ఒకే ఫీల్డ్‌లో విలువలను నిల్వ చేయడానికి శ్రేణిని ఉపయోగించడం ద్వారా మీరు డేటాబేస్‌లో బహుళ చెక్‌బాక్స్ విలువలను నిల్వ చేయవచ్చు. మీరు దీన్ని ఎలా చేయగలరో ఇక్కడ ఒక ఉదాహరణ:

1. చెక్‌బాక్స్ విలువలను నిల్వ చేయడానికి మీ డేటాబేస్ పట్టికకు ఫీల్డ్‌ను జోడించడానికి మైగ్రేషన్‌ను సృష్టించండి. ఉదాహరణకు, మీరు "ఐచ్ఛికాలు" అనే ఫీల్డ్‌లో విలువలను నిల్వ చేయాలనుకుంటే, మీరు క్రింది మైగ్రేషన్‌ని ఉపయోగించవచ్చు:

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class AddOptionsToTableName extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::table('table_name', function (Blueprint $table) {
            $table->text('options')->nullable();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::table('table_name', function (Blueprint $table) {
            $table->dropColumn('options');
        });
    }
}

2. మీ ఫారమ్‌లో, మీరు సేవ్ చేయాలనుకుంటున్న ప్రతి ఎంపిక కోసం చెక్‌బాక్స్‌లను సృష్టించండి. ఉదాహరణకి :

<input type="checkbox" name="options[]" value="option1"> Option 1
<input type="checkbox" name="options[]" value="option2"> Option 2
<input type="checkbox" name="options[]" value="option3"> Option 3

3. మీ ఫారమ్ సమర్పణ ప్రాసెసింగ్ లాజిక్‌లో, ఎంచుకున్న చెక్‌బాక్స్‌ల విలువలను తిరిగి పొందండి మరియు వాటిని డేటాబేస్‌లో నిల్వ చేయండి. ఉదాహరణకి :

$options = $request->input('options');

$model = new Model();
$model->options = json_encode($options);
$model->save();

ఇది ఎంచుకున్న చెక్‌బాక్స్‌ల విలువలను "ఐచ్ఛికాలు" ఫీల్డ్‌లో JSON ఎన్‌కోడ్ చేసిన శ్రేణిగా నిల్వ చేస్తుంది. మీరు డేటాబేస్ నుండి రికార్డ్‌ను తిరిగి పొందినప్పుడు JSON శ్రేణిని డీకోడ్ చేయడం ద్వారా ఎంచుకున్న విలువలను తిరిగి పొందవచ్చు మరియు ప్రదర్శించవచ్చు.

$model = Model::find($id);
$options = json_decode($model->options);

లారావెల్‌లో బహుళ చెక్‌బాక్స్ విలువలను నిల్వ చేయడానికి నమూనా కోడ్‌లు

లారావెల్‌లోని డేటాబేస్‌లో బహుళ చెక్‌బాక్స్‌ల విలువలను నిల్వ చేయడానికి ఇక్కడ కొన్ని నమూనా కోడ్‌లు ఉన్నాయి:

"బూలియన్" రకం ఫీల్డ్‌ని ఉపయోగించండి

“యూజర్‌లు” పట్టికలో “సబ్‌స్క్రిప్షన్_న్యూస్‌లెటర్” బూలియన్ కాలమ్ సృష్టి:

Schema::table('utilisateurs', function (Blueprint $table) {
    $table->boolean('abonnement_newsletter')->default(0);
});

ఫారమ్‌ను సమర్పించేటప్పుడు వార్తాలేఖకు వినియోగదారు సభ్యత్వాన్ని నమోదు చేయడం:

$utilisateur = new Utilisateur;
$utilisateur->abonnement_newsletter = $request->input('abonnement_newsletter');
$utilisateur->save();

"టెక్స్ట్" టైప్ ఫీల్డ్‌ని ఉపయోగించండి

"సర్వే" పట్టికలో వచన రకం యొక్క "options_sélectionées" నిలువు వరుసను సృష్టించడం:

Schema::table('sondage', function (Blueprint $table) {
    $table->text('options_sélectionnées');
});

ఫారమ్‌ను సమర్పించేటప్పుడు వినియోగదారు ఎంచుకున్న ఎంపికలను సేవ్ చేయడం:

$sondage = new Sondage;
$sondage->options_sélectionnées = implode(',', $request->input('options'));
$sondage->save();

సంబంధాల పట్టికను ఉపయోగించండి

"id_product" మరియు "id_category" నిలువు వరుసలతో "categories_products" పట్టికను సృష్టించడం:

Schema::create('catégories_produits', function (Blueprint $table) {
    $table->bigIncrements('id');
    $table->integer('id_produit');
    $table->integer('id_catégorie');
    $table->timestamps();
});

ఫారమ్‌ను సమర్పించేటప్పుడు వినియోగదారు ఎంచుకున్న వర్గాలను సేవ్ చేస్తోంది:

$produit = new Produit;
$produit->save();

foreach ($request->input('catégories') as $catégorie) {
    $catégorie_produit = new CatégorieProduit;
    $catégorie_produit->id_produit = $produit->id;
    $catégorie_produit->id_catégorie = $catégorie;
    $catégorie_produit->save();
}

"టేబుల్" రకం ఫీల్డ్‌ను ఉపయోగించండి

పట్టిక "పోల్"లో పట్టిక రకం "options_selected" నిలువు వరుసను సృష్టించడం (మీరు PostgreSQL ఉపయోగిస్తే):

Schema::table('sondage', function (Blueprint $table) {
    $table->jsonb('options_sélectionnées');
});

ఫారమ్‌ను సమర్పించేటప్పుడు వినియోగదారు ఎంచుకున్న ఎంపికలను సేవ్ చేయడం:

$sondage = new Sondage;
$sondage->options_sélectionnées = $request->input('options');
$sondage->save();

ఏ సందర్భంలోనైనా, మీ డేటాబేస్‌లో సేవ్ చేయడానికి ముందు మీ చెక్‌బాక్స్ విలువలు సరిగ్గా ధృవీకరించబడి, శుభ్రం చేయబడి ఉన్నాయని మీరు నిర్ధారించుకోవాల్సిన అవసరం ఉందని గమనించడం ముఖ్యం. మీరు దీని కోసం లారావెల్ యొక్క ధ్రువీకరణ కంట్రోలర్‌లు మరియు డేటా ఫిల్టర్‌లను ఉపయోగించవచ్చు.

[మొత్తం: 1 అర్థం: 5]

వ్రాసిన వారు అంటోన్ గిల్డెబ్రాండ్

అంటోన్ తన సహోద్యోగులు మరియు డెవలపర్ కమ్యూనిటీతో చిట్కాలు మరియు కోడ్ సొల్యూషన్‌లను పంచుకోవాలనే అభిరుచి కలిగిన పూర్తి స్టాక్ డెవలపర్. ఫ్రంట్-ఎండ్ మరియు బ్యాక్-ఎండ్ టెక్నాలజీలలో ఘనమైన నేపథ్యంతో, అంటోన్ వివిధ రకాల ప్రోగ్రామింగ్ లాంగ్వేజ్‌లు మరియు ఫ్రేమ్‌వర్క్‌లలో ప్రావీణ్యం కలిగి ఉన్నాడు. అతను ఆన్‌లైన్ డెవలపర్ ఫోరమ్‌లలో చురుకైన సభ్యుడు మరియు ప్రోగ్రామింగ్ సవాళ్లను పరిష్కరించడంలో ఇతరులకు సహాయపడటానికి క్రమం తప్పకుండా ఆలోచనలు మరియు పరిష్కారాలను అందజేస్తాడు. తన ఖాళీ సమయంలో, అంటోన్ ఫీల్డ్‌లోని తాజా పోకడలు మరియు సాంకేతికతలపై తాజాగా ఉండడం మరియు కొత్త సాధనాలు మరియు ఫ్రేమ్‌వర్క్‌లతో ప్రయోగాలు చేయడం ఆనందిస్తాడు.

సమాధానం ఇవ్వూ

మొబైల్ వెర్షన్ నుండి నిష్క్రమించండి