[英]Creating a dynamic multidimensional array from MYSQL filters
我一直在尋找正確的格式來從數據庫過濾器創建多維數組。 我正在為一個項目使用常量接觸 php 包裝器,該項目需要精確的格式來加載 email 地址、名字和姓氏的數組。 有關 class 將接受的數組的正確格式,請參見下文:
<php?
$contacts = array(
array(
'Email Address' => 'test@test.com',
'First Name' => 'Mike - TEST API',
'Last Name' => 'NULL',
)
);
我現在擁有的代碼如下:
<form action="<?php echo $PHP_SELF;?>" method="get" name="form" target="_self" id="form">
<p>
<select name="networks[]" size="50" multiple>
<option value="West Bronx">West Bronx</option>
<option value="Williamsburg">Williamsburg</option>
<option value="Turtle Bay">Turtle Bay</option>
<option value="Times Square">Times Square</option>
<option value="Southeast Bronx">Southeast Bronx</option>
<option value="Sutton">Sutton</option>
<option value="Sunnyside">Sunnyside</option>
<option value="Sheridan Square">Sheridan Square</option>
<option value="Sheepshead">Sheepshead</option>
<option value="Roosevelt">Roosevelt</option>
<option value="Riverdale">Riverdale</option>
<option value="Ridgewood">Ridgewood</option>
<option value="Richmond Hill">Richmond Hill</option>
<option value="Battery Park City Network">Battery Park City Network</option>
<option value="Yorkville">Yorkville</option>
</select>
<br>
<input type="submit" name="Submit" value="Submit">
</form>
<?
// Get the value of the filters and see if there are more then one selection
$foo = $_GET['networks'];
$sQuery = "";
if (sizeof($foo) > 0) {
for ($i=0;$i<sizeof($foo);$i++) {
$sQuery .= "Network LIKE '%$foo[$i]%' OR ";
}
}
else{
$sQuery = "Network LIKE '%$foo[0]%";
}
mysql_select_db($database_conn, $conn);
$query_Recordset0 = "SELECT * FROM contacts WHERE $sQuery ";
// Knock the last "OR" off the Query
$query_Recordset1 = substr($query_Recordset0, 0, -4);
echo $query_Recordset1;
$Recordset1 = mysql_query($query_Recordset1, $conn) or die(mysql_error());
?>
<table width="200" border="0" cellpadding="0" cellspacing="0">
<tr>
<td>Network</td>
<td>Email</td>
</tr>
<?php do { ?>
<tr>
<td><?php echo $row_Recordset1['Network']; ?></td>
<td><?php echo $row_Recordset1['Email']; ?></td>
<td><?php echo $row_Recordset1['First Name']; ?></td>
<td><?php echo $row_Recordset1['Last Name']; ?></td>
</tr>
<?php
//BUILD The Multidimensional Array from the database Query and store it appropriately
$newarray = array();
$newarray[]['Email Address']=$row_Recordset1['Email'];
$newarray[]['First Name']='NULL';
$newarray[]['Last Name']='Last Name';
print_r($newarray);
這會產生這樣的數組:
Array (
[0] => Array ( [Email Address] => )
[1] => Array ( [First Name] => NULL )
[2] => Array ( [Last Name] => Last Name ) )
Array (
[0] => Array ( [Email Address] => silverslammer@aol.com )
[1] => Array ( [First Name] => NULL )
[2] => Array ( [Last Name] => Last Name ) )
Array (
[0] => Array ( [Email Address] => shlomi@lmopticaldisc.com )
[1] => Array ( [First Name] => NULL )
[2] => Array
任何幫助將不勝感激。
下面是我需要它的樣子:
$contacts = array(
array(
'Email Address' => 'test@test.com',
'First Name' => 'Mike - TEST API',
'Last Name' => 'NULL',
)
);
$newarray[] = array(
'Email Address'=>$row_Recordset1['Email'];
'First Name'=>'NULL';
'Last Name'=>'Last Name';
);
print_r($newarray);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.