как извлечь данные из БД, используя AJAX - PullRequest
0 голосов
/ 17 апреля 2020

Я хочу получить данные из БД на панель пользователя. Идентификация пользователя с использованием номера контакта

Я запускаю запрос AJAX, чтобы получить все добавления. он работает хорошо.

но мне нужно получить данные под его идентификатором пользователя (ContactNo). здесь я добавляю AJAX код.

user data avaiable in AUTH -> {{ Auth::user()->ContactNo }}

$(document).ready(function($){
  //alert("jquery running");
  getAll();

});

  //getting all rows from the database
    function getAll() {

        $.ajax({
            url: '{{ route('Myadds', app()->getLocale()) }}',
            type: 'GET',

        })
        .done(function(data) {
      alert("run")
        $.each(data, function(index, val) {
             $('#data').append('<tr>')
             $('#data').append('<td>'+val.id+'</td>')
             $('#data').append('<td>'+val.Sdescription+'</td>')
             $('#data').append('<td>'+val.created_at+'</td>')
             $('#data').append('<td><button class="btn btn-xs btn-danger" data-id="'+val.id+'">Delete</button><button class="btn btn-xs btn-info" data-id="'+val.id+'">Edit</button></td>')
             $('#data').append('</tr>')
        });
        })
        .fail(function() {
      alert("fail")
            console.log("error");
        })

    }

</script>

Ответы [ 2 ]

0 голосов
/ 19 апреля 2020
    public function Myadds(){

        try{
            return add::where('userID', Auth::user()->ContactNo)->get();  


        }catch(Exception $e){
            return 'false';
        }
        }
0 голосов
/ 18 апреля 2020

Вам необходимо передать параметр de contactNo в вашем запросе:

  function getAll() {

        $.ajax({
            url: '{{ route('Myadds', app()->getLocale()) }}',
            type: 'GET',
            data: { 
              contact_no: contactNo, 
            },
        })
        .done(function(data) {
        alert("run")
        $.each(data, function(index, val) {
             $('#data').append('<tr>')
             $('#data').append('<td>'+val.id+'</td>')
             $('#data').append('<td>'+val.Sdescription+'</td>')
             $('#data').append('<td>'+val.created_at+'</td>')
             $('#data').append('<td><button class="btn btn-xs btn-danger" data-id="'+val.id+'">Delete</button><button class="btn btn-xs btn-info" data-id="'+val.id+'">Edit</button></td>')
             $('#data').append('</tr>')
        });
        })
        .fail(function() {
      alert("fail")
            console.log("error");
        })

    }

Итак, теперь в вашем контроллере вы можете фильтровать:

public function getData(Request $request){
     $contact_no = $request->contact_no; 
     
     $query = DB::table('my_table');
     
     if($contact_no){
        $query->where('contact_no',$contact_no)
     }
     
    return response()->json($query->get());
}

Или напрямую использовать сеанс пользователя:

public function getData(Request $request){
     $contact_no = Auth::user()->ContactNo; 
     
     $query = DB::table('my_table');
     
     $query->where('contact_no',$contact_no)

    return response()->json($query->get());
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...