Como analisar os resultados da linha de $ WPDB -> get_results
4 respostas
- votos
-
- 2011-07-19
foreach( $wpdb->get_results("SELECT * FROM your_table_name WHERE id LIKE' . $id . ';") as $key => $row) { // each column in your row will be accessible like this $my_column = $row->column_name;}
foreach( $wpdb->get_results("SELECT * FROM your_table_name WHERE id LIKE' . $id . ';") as $key => $row) { // each column in your row will be accessible like this $my_column = $row->column_name;}
More info here
-
Nãotenho certeza seesta é amaneira certa.Acho que se deve obter o resultadopara uma variávele usarforeach sobreisso,para ser seguro.Porexemplo.$ Resultados=$ WPDB-> Get_Results ($ SQL);e,em seguida,usarforeach (US $ resultados como $ valor).not sure if this is the right way though. I think one should get the result to a variable and use foreach on that, to be safe. E.g. $results = $wpdb->get_results($sql); and then use foreach($results as $value).
- 2
- 2013-09-13
- Gogol
-
Não deveimportar realmentenestainstância,uma vez que retornamatriz,objeto ounulo,não deve haver risco de obter um recurso de "loop hostis".Isso dizia que vocêpode querer ligar-osnovamentepara outra coisa,e se assim definitivamente armazená-lo.Não consulte duas vezesshouldn't really matter in this instance since it returns array, object or null, there shouldn't be any risk of getting a "loop unfriendly" resource. that said you may want to loop through them again for something else, and if so definitely store it. don't query twice
- 0
- 2017-10-29
- Garet Claborn
-
- 2011-07-19
Sempretente o WordPress Codex: http://codex.wordpress.org/class_reference/wpdb#select_generic_results
Essencialmente dada a sintaxepadrão,a variável $ linha aqui é um objeto que contém seus resultados.Vocêpode alternativamenteespecificar otipo de resultado (arraynumérico,matriz associativa).
Assumindo apenas um resultado,em seguida,$ row-> IDe $ row->nome devefornecer asinformações.
Se você voltarmais de um resultado,vocêgostaria de ligar asentradasno objeto.
Se vocêestiveresperando apenas uma linha de volta,tente usar $ WPDB->get_row http://codex.wordpress.org/class_reference/wpdb#select_a_row
Always Try the WordPress Codex: http://codex.wordpress.org/Class_Reference/wpdb#SELECT_Generic_Results
Essentially given the default syntax, the variable $row here is an object containing your results. You could alternately specify the TYPE of result (numeric array, associative array).
Assuming just one result, then $row->id and $row->name should give you the information.
If you get back more than one result, you'd want to loop over the entries in the object.
If you are expecting just one row back, then try using $wpdb->get_row http://codex.wordpress.org/Class_Reference/wpdb#SELECT_a_Row
-
- 2017-10-30
usar como umamatriz associativa:
$obj=[]; $rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , ARRAY_A); foreach($rows as $row){ $obj=$row; break; } // $obj is now the selected row if a match was found
Uso
$something = $obj['column_name']; foreach($obj as $col => $val) echo $col . ': ' . $val . PHP_EOL . '<br />';
Para obter outrosformatos,basta alterar
ARRAY_A
combaseno Documentaçãopara$wpdb->get_results()
. A resposta da Pippin é apropriadapara amaioria dos objetos.para usar uma linha como um arraynumericamenteindexado
$rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , ARRAY_N); foreach($rows as $row){ $obj=$row; break; } //Usage foreach($obj as $col_value) echo $col_value . ' ';
Para usar uma linhaem umamatriz cujasteclas são a chaveprimária dobanco de dados (muitas vezes um
id
). Possivelmentemaiseficiente do que ométodo dematriz associativo.$rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , OBJECT_K); $obj = $rows[ $obj_id ]; //Usage $something = $obj->column_name; //Remember you can loop over objects too foreach($obj as $col => $val) echo $col . ': ' . $val . PHP_EOL;
To use as an associative array:
$obj=[]; $rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , ARRAY_A); foreach($rows as $row){ $obj=$row; break; } // $obj is now the selected row if a match was found
Usage
$something = $obj['column_name']; foreach($obj as $col => $val) echo $col . ': ' . $val . PHP_EOL . '<br />';
To get other formats, simply change
ARRAY_A
based on the documentation for$wpdb->get_results()
. Pippin's answer is appropriate for most object use.To use one row as an numerically indexed array
$rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , ARRAY_N); foreach($rows as $row){ $obj=$row; break; } //Usage foreach($obj as $col_value) echo $col_value . ' ';
To use one row in an array whose keys are the primary key from your database(often an
id
column). Possibly more efficient than the associative array method.$rows = $wpdb->get_results( 'SELECT * FROM `tbl_name` WHERE `id` = '.$obj_id , OBJECT_K); $obj = $rows[ $obj_id ]; //Usage $something = $obj->column_name; //Remember you can loop over objects too foreach($obj as $col => $val) echo $col . ': ' . $val . PHP_EOL;
-
- 2018-03-15
Este códigofuncionaperfeitoparamim:
global $wpdb; $table_name = "my_table_name"; $myrows = $wpdb->get_results( "SELECT `id`, `name` FROM ".$table_name); foreach ($myrows as $details) { echo $details->id; echo $details->name;}
This code work perfect for me:
global $wpdb; $table_name = "my_table_name"; $myrows = $wpdb->get_results( "SELECT `id`, `name` FROM ".$table_name); foreach ($myrows as $details) { echo $details->id; echo $details->name;}
Eutenho o seguinte:
Como obtenho as colunas denominadas "ID"e "nome" de $ ROW?