根据 ID 的值选择数据
Posted
技术标签:
【中文标题】根据 ID 的值选择数据【英文标题】:Select data based on value of ID 【发布时间】:2017-06-04 09:55:09 【问题描述】:我正在尝试根据一个值选择数据,我有一个从团队表中选择数据的表单,我需要从选择下拉列表中获取该行的 ID(我可以这样做),然后使用确定在我执行 AJAX 请求时需要选择的数据。如下:
团队页面 - 此页面绘制我的图表,该图表通过 AJAX 提取数据以绘制图表及其值:
<form action="teams.php?dashboard_id=<?php echo $dashboard_id; ?>" method="POST">
<select name="teamId">
<option selected="true" disabled="disabled">Please choose...</option>
<?php
$sql = "SELECT * FROM teams WHERE dashboard_id = $dashboard_id";
$result = $conn->query($sql);
if($result->num_rows > 0)
while($row = $result->fetch_assoc())
echo '<option value=' . $row["team_id"] . '>' . $row["team_name"] . '</option>';
?>
</select>
<button class="compare">View</button>
</form>
<?php
if (!empty($_POST["teamId"]))
$teamSelect = $_POST["teamId"];
echo $teamSelect;
else
echo "";
?>
<div style="max-width: 450px;">
<canvas id="mycanvas" class="container"></canvas>
</div>
这是我执行 SELECT 的 PHP 页面:
<?php
include 'config.php';
$teamID = $_POST['teamId'];
$query = sprintf("SELECT
tm.member_id,
tm.team_id,
m.member_id,
m.firstName,
m.lastName,
m.score_1,
m.score_2,
m.score_3,
m.score_4,
m.score_5,
m.score_6,
m.score_7,
m.score_8,
m.dashboard_id,
t.team_id,
t.team_name,
t.dashboard_id
FROM team_members tm
JOIN members AS m
on m.member_id = tm.member_id
JOIN teams AS t
on t.team_id = tm.team_id
WHERE tm.team_id = '$teamID'"); // This need to be dynamic and got from the POST request on the form above.
$result = $conn->query($query);
$data = array();
foreach ($result as $row)
$data[] = $row;
$result->close();
$conn->close();
header('Content-type: application/json');
print json_encode($data);
?>
我正在通过另一个文件绘制图表:
$(document).ready(function()
$.ajax(
url : "http://localhost/acredashAdv/teamData.php",
type : "GET",
success :function(data)
console.log(data);
var chartata =
labels: [
"Strategic Development and Ownership",
"Driving change through others",
"Exec Disposition",
"Commercial Acumen",
"Develops High Performance Teams",
"Innovation and risk taking",
"Global Leadership",
"Industry Leader"
];
var ctx = $("#mycanvas");
var config =
type: 'radar',
data: chartata,
animationEasing: 'linear',
options:
legend:
display: true,
position: 'bottom'
,
tooltips:
enabled: true
,
scale:
ticks:
fontSize: 15,
beginAtZero: true,
stepSize: 1
,
,
LineGraph = new Chart(ctx, config);
var colorArray = [
["#7149a5", false],
["#58b7e0", false],
["#36bfbf", false],
["#69bd45", false],
["#5481B1", false],
["#6168AC", false]
];
for (var i in data)
tmpscore=[];
tmpscore.push(data[i].score_1);
tmpscore.push(data[i].score_2);
tmpscore.push(data[i].score_3);
tmpscore.push(data[i].score_4);
tmpscore.push(data[i].score_5);
tmpscore.push(data[i].score_6);
tmpscore.push(data[i].score_7);
tmpscore.push(data[i].score_8);
var color, done = false;
while (!done)
var test = colorArray[parseInt(Math.random() * 6)];
if (!test[1])
color = test[0];
colorArray[colorArray.indexOf(test)][1] = true;
done = !done;
newDataset =
label: data[i].firstName+' '+data[i].lastName,
borderColor: color,
backgroundColor: "rgba(0,0,0,0)",
data: tmpscore,
;
config.data.datasets.push(newDataset);
LineGraph.update();
,
);
);
这一切都很好,但是在我的选择查询中,我需要 WHERE 子句向我显示根据团队 ID 的值而不是静态值确定的数据,但我不确定如何将 ID 从选择传递回AJAX 文件?
【问题讨论】:
您是在寻找 WHERE 子句的键和值还是只是值? 我试图获得一个选择下拉菜单,以便能够根据 where 子句进行选择,例如,如果我的下拉值是id_1
而 where 子句是 id_1
,它将显示来自该子句的数据排。我什至无法让该文件查看 ID
基本上我希望能够从我的选择表单发布到 SELECT 子句所在的页面,然后使用该值作为 WHERE 子句发布
你为什么使用没有%x
php.net/manual/en/function.sprintf.php的sprintf?
然后使用会话。 $_SESSION['teamID'] = $teamID。然后你可以在任何地方引用它...确保在每个 php 文件的顶部开始会话。 php.net/manual/en/function.session-start.php
【参考方案1】:
然后使用会话。 $_SESSION['teamID'] = $teamID
。然后你可以在任何地方引用它。请务必使用会话在每个 php 文件的顶部启动会话。
session_start();
$teamID = $_POST['teamId'];
$_SESSION['teamID'] = $teamID;
参考资料:
http://php.net/manual/en/function.session-start.php http://php.net/manual/en/book.session.php【讨论】:
但是,如果我可以建议,总是测试会话是否设置/不为空,因为它可能会在以后造成问题,并且一旦不需要它就销毁会话,因为它可能会导致意外结果。 同意。负责任地处理会话;) @PhpDude 小心;unset
和销毁会话是两种不同的动物。
@Skippy 我希望你不介意编辑。 “让我知道”已替换为我从您那里发布的内容中借来的评论。
@Fred-ii- 我将对此进行一些认真的测试,以找出任何问题,并确保它不会哔哔声以上是关于根据 ID 的值选择数据的主要内容,如果未能解决你的问题,请参考以下文章
根据来自 2 个不同命中级别数据 Bigquery 的值选择 VISITID