Heim > Datenbank > MySQL-Tutorial > MYSQL语句生成器

MYSQL语句生成器

WBOY
Freigeben: 2016-06-07 15:14:59
Original
1689 Leute haben es durchsucht

看到一位网友用JS做了一个这样一个类似的东西,于是试着用PHP试试看效果。 多提意见,谢谢! MYSQL语句生成器 2005-01-11 初步模型 2005-01-13 修改了可以输入数字及数字为开头的表名、字段和主键的BUG 2005-01-17 加入代码生成历史记录下拉菜单,加入数据库

看到一位网友用JS做了一个这样一个类似的东西,于是试着用PHP试试看效果。
多提意见,谢谢!

MYSQL语句生成器

2005-01-11  初步模型
2005-01-13  修改了可以输入数字及数字为开头的表名、字段和主键的BUG
2005-01-17  加入代码生成历史记录下拉菜单,加入数据库连接部分,并重新修改整体程序模块

源代码:
====================
/*
 * mysql语句生成器
 * 创建时间:2005-01-11
 * 作  者:多菜鸟
 * 来  源: http://blog.csdn.net/kingerq
 * 联系邮箱: kingerq AT msn DOT com
 */
session_start();
$code = array();
$line = array("=================插入语句=================",
   "=================选择语句=================",
   "=================更新语句=================");
$js = "";
$typein = array();
$tbl_list = $tbltemp = "";

if($_POST){
 if(array_key_exists("tbl_name", $_POST)){
  $tbltemp = $_POST["tbl_name"];
  $_POST = $_SESSION["phpcode"][$_POST["tbl_name"]];
  //print_r($_SESSION["phpcode"]);
 }else{
  $_SESSION["phpcode"][$_POST["tbl"]] = $_POST;
 }
 $code[0] = createcode($_POST, 0);//插入语句
 $code[1] = createcode($_POST, 1);//选择语句
 $code[2] = createcode($_POST, 2);//更新语句
 $typein = $_POST["outtype"];
 
 foreach($typein as $val){
  $js .= "code[/"outtype[]/"][".$val."].checked = true;/n";
 }
 echo "<script><br/> window.onload = function(){<br/> code.tbl.value = '".$_POST["tbl"]."';<br/> code.fieldlist.value = '".$_POST["fieldlist"]."';<br/> code.keyword.value = '".$_POST["keyword"]."';<br/> code.codetype[".$_POST["codetype"]."].checked = true;<br/> ".$js."<br/> }<br/> </script>";
}
//创建历史下拉菜单
if(!empty($_SESSION["phpcode"])){
 foreach(array_filter(array_reverse($_SESSION["phpcode"])) as $key => $val){
  $tbl_list .= "";
 }
}

/*
 * 生成语句函数
 */
function createcode($ar, $type = 0){
 switch($type){
  case 1://选择语句处理
   $sql = "/$sql = /"SELECT ".fieldlist($ar["fieldlist"])." /nFROM `".$ar["tbl"]."` ".where($_POST["keyword"])."/";/n";
   
   break;
  case 2://更新语句处理
   $sql = "/$sql = /"UPDATE `".$ar["tbl"]."` SET ".fieldlist($ar["fieldlist"], 2)." ".where($_POST["keyword"])." LIMIT 1/";/n";
   
   break;
  default://插入语句处理
   $sql = "/$sql = /"INSERT INTO `".$ar["tbl"]."`(".fieldlist($ar["fieldlist"]).")/nVALUES(".fieldlist($ar["fieldlist"], 1).")/";/n";
   
 }
 if($ar["codetype"]){//输出PHPLIB
  $sql  = "include(/"inc/db_mysql.inc/");//包括MYSQL操作类/n/$db = new DB_Sql;//定义类/n/$db->connect();//连接数据库/n/n".$sql;
  $sql .= "/$db->query(/$sql);/n";
 }else{
  $sql = "/* 连接数据库 *//n/$conn = mysql_pconnect(/"localhost/", /"username/", /"password/") or die(/"不能连接数据库:/".mysql_error());/n/* 选择数据库 *//nmysql_select_db(/"mysql_database/") or die(/"不能选择数据库/");/n/n".$sql;
  $sql .= "/$result = mysql_query(/$sql);/n";
 }
 return $sql;
}
/*
 * 字段处理
 */
function fieldlist($fieldstr, $type = 0){
 $str = "";
 $tstr = split(",", $fieldstr);
 foreach($tstr as $val){
  switch($type){
   case 1://用在插入语句中
    if($str) $str .= ", ";
    $str .= "'/"./$_POST[/"".trim($val)."/"]./"'";
    break;
   case 2://用在更新语句中
    if($str) $str .= ", /n";
    $str .= "`".trim($val)."` = '/"./$_POST[/"".trim($val)."/"]./"'";
    break;
   default:
    if($str) $str .= ", ";
    $str .= "`".trim($val)."`";
  }
 }
 return $str;
}

function where($keyword){
 return "/nWHERE `$keyword` = '/"./$_POST[/"".$keyword."/"]./"'";
}
?>

MYSQL语句生成器
 
   
   
 
 
 
返回

     
   if($tbl_list){
   ?>
  
     
   }
   ?>
   

 


   
     
     
   
   
     
     
   
   
     
     
   
   
     
     
   
   
     
     
   
   
     
     
   

表名:
字段列表:
     

      用逗号(,)分开各字段
主键字段:
代码类型:
        一般代码
       
      PHPLIB
输出类型:
        插入
         
          选择
         
          更新
 
     

 


 
   
 

foreach($code as $key=>$val){
 if(in_array($key, $typein)) {
  echo $line[$key]."
/n ";
  highlight_string("/n");
 }
}
?>

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage