Update sql_query_result.php

This commit is contained in:
Nate 2019-09-06 12:36:54 -06:00
parent fd242efc88
commit 6408175309
1 changed files with 46 additions and 29 deletions

View File

@ -58,6 +58,21 @@
exit;
}
//get allowed table names
switch ($db_type) {
case 'sqlite': $sql = "select name from sqlite_master where type='table' order by name;"; break;
case 'pgsql': $sql = "select table_name as name from information_schema.tables where table_schema='public' and table_type='BASE TABLE' order by table_name"; break;
case 'mysql': $sql = "show tables"; break;
}
$database = new database;
$rows = $database->select($sql, null, 'all');
if (is_array($rows) && @sizeof($rows) != 0) {
foreach ($rows as $row) {
$tables[] = $row['name'];
}
}
unset($sql, $rows, $row);
//show the content
if (is_array($_POST)) {
$sql_type = trim($_POST["sql_type"]);
@ -131,7 +146,7 @@
//determine queries to run and show
if ($sql_cmd != '') { $sql_array = array_filter(explode(";", $sql_cmd)); }
if ($table_name != '') { $sql_array[] = "select * from ".$table_name; }
if ($table_name != '' && in_array($table_name, $tables)) { $sql_array[] = "select * from ".$table_name; }
$show_query = (sizeof($sql_array) > 1) ? true : false;
if (is_array($sql_array)) foreach($sql_array as $sql_index => $sql) {
@ -203,7 +218,7 @@
$sql = trim($sql);
//get the table data
$sql = (strlen($sql_cmd) == 0) ? "select * from ".$table_name : $sql_cmd;
$sql = (strlen($sql_cmd) == 0 && in_array($table_name, $tables)) ? "select * from ".$table_name : $sql_cmd;
if (strlen($sql) > 0) {
$database = new database;
@ -230,34 +245,36 @@
}
$column_array_count = count($column_array);
if (is_array($result)) foreach ($result as $index => &$row) {
if (is_array($result)) {
foreach ($result as $index => &$row) {
echo "<div style='font-family: monospace; border-bottom: 1px solid #ccc; padding-bottom: 8px; ".($index != 0 ? 'padding-top: 8px;' : null)."'>\n";
echo "insert into ".$table_name." (";
if (is_array($column_array)) {
foreach ($column_array as $column) {
if ($column != "menuid" && $column != "menuparentid") {
$columns[] = $column;
echo "<div style='font-family: monospace; border-bottom: 1px solid #ccc; padding-bottom: 8px; ".($index != 0 ? 'padding-top: 8px;' : null)."'>\n";
echo "insert into ".$table_name." (";
if (is_array($column_array)) {
foreach ($column_array as $column) {
if ($column != "menuid" && $column != "menuparentid") {
$columns[] = $column;
}
}
}
}
if (is_array($columns) && sizeof($columns) > 0) {
echo implode(', ', $columns);
}
echo ") values (";
if (is_array($column_array)) {
foreach ($column_array as $column) {
if ($column != "menuid" && $column != "menuparentid") {
$values[] = $row[$column] != '' ? "'".escape(check_str($row[$column]))."'" : 'null';
if (is_array($columns) && sizeof($columns) > 0) {
echo implode(', ', $columns);
}
echo ") values (";
if (is_array($column_array)) {
foreach ($column_array as $column) {
if ($column != "menuid" && $column != "menuparentid") {
$values[] = $row[$column] != '' ? "'".escape($row[$column])."'" : 'null';
}
}
}
if (is_array($values) && sizeof($values) > 0) {
echo implode(', ', $values);
}
echo ");\n";
echo "</div>\n";
unset($columns, $values);
}
if (is_array($values) && sizeof($values) > 0) {
echo implode(', ', $values);
}
echo ");\n";
echo "</div>\n";
unset($columns, $values);
}
}
@ -271,15 +288,15 @@
if (strlen($sql_cmd) > 0) {
header('Content-Disposition: attachment; filename=data.csv');
}
else {
header('Content-Disposition: attachment; filename='.escape($table_name).'.csv');
else if (in_array($table_name, $tables)) {
header('Content-Disposition: attachment; filename='.$table_name.'.csv');
}
//get the table data
if (strlen($sql_cmd) > 0) {
$sql = $sql_cmd;
}
else {
else if (in_array($table_name, $tables)) {
$sql = "select * from ".$table_name;
}
if (strlen($sql) > 0) {
@ -316,7 +333,7 @@
foreach ($result as &$row) {
$x = 1;
foreach ($column_array as $column) {
echo '"'.escape($row[$column]).'"'.(($x++ < count($column_array)) ? ',' : null);
echo '"'.$row[$column].'"'.($x++ < count($column_array) ? ',' : null);
}
echo "\n";
}
@ -325,4 +342,4 @@
}
}
?>
?>