" /> 亚洲九九精品,两个人在线观看的视频720,午夜精品久久久久久99热蜜桃

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

如何利用PHP執行.SQL文件

demo.php:
復制代碼 代碼如下:
<?php
/**
* 讀取 sql 文件并寫入數據庫
* @version 1.01 demo.php
*/
class DBManager
{
    var $dbHost = '';
    var $dbUser = '';
    var $dbPassword = '';
    var $dbSchema = '';

    function __construct($host,$user,$password,$schema)
    {
        $this->dbHost = $host;
        $this->dbUser = $user;
        $this->dbPassword = $password;
        $this->dbSchema = $schema;
    }

    function createFromFile($sqlPath,$delimiter = '(;/n)|((;/r/n))|(;/r)',$prefix = '',$commenter = array('#','--'))
    {
        //判斷文件是否存在
        if(!file_exists($sqlPath))
            return false;

        $handle = fopen($sqlPath,'rb');  

        $sqlStr = fread($handle,filesize($sqlPath));

        //通過sql語法的語句分割符進行分割
        $segment = explode(";",trim($sqlStr));

        //var_dump($segment);

        //去掉注釋和多余的空行
        foreach($segment as & $statement)
        {
            $sentence = explode("/n",$statement);

            $newStatement = array();

            foreach($sentence as $subSentence)
            {
                if('' != trim($subSentence))
                {
                    //判斷是會否是注釋
                    $isComment = false;
                    foreach($commenter as $comer)
                    {
                        if(eregi("^(".$comer.")",trim($subSentence)))
                        {
                            $isComment = true;
                            break;
                        }
                    }
                    //如果不是注釋,則認為是sql語句
                    if(!$isComment)
                        $newStatement[] = $subSentence;                  
                }
            }

            $statement = $newStatement;
        }
        //對表名加前綴
        if('' != $prefix)
        {

      
            //只有表名在第一行出現時才有效 例如 CREATE TABLE talbeName

            $regxTable = "^[/`/'/"]{0,1}[/_a-zA-Z]+[/_a-zA-Z0-9]*[/`/'/"]{0,1}$";//處理表名的正則表達式
            $regxLeftWall = "^[/`/'/"]{1}";

            $sqlFlagTree = array(
                    "CREATE" => array(
                            "TABLE" => array(
                                    "$regxTable" => 0
                                )
                        ),
                    "INSERT" => array(
                            "INTO" => array(
                                "$regxTable" => 0
                            )
                        )

                    );

            foreach($segment as & $statement)
            {
                $tokens = split(" ",$statement[0]);

                $tableName = array();
                $this->findTableName($sqlFlagTree,$tokens,0,$tableName);

                if(empty($tableName['leftWall']))
                {
                    $newTableName = $prefix.$tableName['name'];
                }
                else{
                    $newTableName = $tableName['leftWall'].$prefix.substr($tableName['name'],1);
                }

                $statement[0] = str_replace($tableName['name'],$newTableName,$statement[0]);
            }

        }      
        //組合sql語句
        foreach($segment as & $statement)
        {
            $newStmt = '';
            foreach($statement as $sentence)
            {
                $newStmt = $newStmt.trim($sentence)."/n";
            }

            $statement = $newStmt;
        }

        //用于測試------------------------      
        //var_dump($segment);
        //writeArrayToFile('data.txt',$segment);
        //-------------------------------

        self::saveByQuery($segment);

        return true;
    }

    private function saveByQuery($sqlArray)
    {
        $conn = mysql_connect($this->dbHost,$this->dbUser,$this->dbPassword);

        mysql_select_db($this->dbSchema);

        foreach($sqlArray as $sql)
        {
            mysql_query($sql);
        }      
        mysql_close($conn);
    }

    private function findTableName($sqlFlagTree,$tokens,$tokensKey=0,& $tableName = array())
    {
        $regxLeftWall = "^[/`/'/"]{1}";

        if(count($tokens)<=$tokensKey)
            return false;      

        if('' == trim($tokens[$tokensKey]))
        {
            return self::findTableName($sqlFlagTree,$tokens,$tokensKey+1,$tableName);
        }
        else
        {
            foreach($sqlFlagTree as $flag => $v)
            {  
                if(eregi($flag,$tokens[$tokensKey]))
                {
                    if(0==$v)
                    {
                        $tableName['name'] = $tokens[$tokensKey];

                        if(eregi($regxLeftWall,$tableName['name']))
                        {
                            $tableName['leftWall'] = $tableName['name']{0};
                        }

                        return true;
                    }
                    else{
                        return self::findTableName($v,$tokens,$tokensKey+1,& $tableName);
                    }
                }
            }
        }

        return false;
    }
}
function writeArrayToFile($fileName,$dataArray,$delimiter="/r/n")
{
    $handle=fopen($fileName, "wb");

    $text = '';

    foreach($dataArray as $data)
    {
        $text = $text.$data.$delimiter;
    }
    fwrite($handle,$text);
}
//測試
$dbM = new DBManager('localhost','w01f','123456','test');
$dbM->createFromFile('data.sql',null,'fff_');
?>

data.sql:
-- phpMyAdmin SQL Dump
-- version 2.11.3
-- http://www.phpmyadmin.NET
--
-- 主機: localhost
-- 生成日期: 2008 年 08 月 20 日 12:09
-- 服務器版本: 5.0.51
-- php 版本: 5.2.5
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
--
-- 數據庫: `newysh`
--
-- --------------------------------------------------------
--
-- 表的結構 `allowed`
--
CREATE TABLE `allowed` (
`bhash` blob NOT NULL,
`bname` varchar(255) character set utf8 NOT NULL,
PRIMARY KEY (`bhash`(20))
) ENGINE=MyISAM DEFAULT CHARSET=gb2312 ROW_FORMAT=DYNAMIC;
--
-- 導出表中的數據 `allowed`
--
-- --------------------------------------------------------
--
-- 表的結構 `allowed_ex`
--
CREATE TABLE `allowed_ex` (
`bhash` blob NOT NULL,
`badded` datetime NOT NULL,
`bsize` bigint(20) unsigned NOT NULL,
`bfiles` int(10) unsigned NOT NULL,
PRIMARY KEY (`bhash`(20))
) ENGINE=MyISAM DEFAULT CHARSET=gb2312 ROW_FORMAT=DYNAMIC;
--
-- 導出表中的數據 `allowed_ex`
--
-- --------------------------------------------------------
--
-- 表的結構 `category`
--
CREATE TABLE `category` (
`cid` int(10) unsigned NOT NULL auto_increment COMMENT '種子分類id',
`name` varchar(255) NOT NULL COMMENT '分類名稱,支持html格式',
`sequence` int(10) unsigned NOT NULL COMMENT '顯示排序,需要小的排在前面',
PRIMARY KEY (`cid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=26 ;
--
-- 導出表中的數據 `category`
--
INSERT INTO `category` (`cid`, `name`, `sequence`) VALUES
(25, '音樂', 23),
(24, '學習資料', 24),
(23, '電影', 25);
-----------------------------------------------------------
注:對于phpmyadmin 生成的sql文件均適用

php技術如何利用PHP執行.SQL文件,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日韩人妻少妇一区二区三区 | 花蝴蝶在线观看中字 | 国产 交换 丝雨 巅峰 | 亚洲2023无矿砖码砖区 | 欧美做真爱欧免费看 | 爱如潮水3免费观看日本 | 国产午夜小视频 | SM双性精跪趴灌憋尿调教H | 美女扒开腿让男生桶免费看动态图 | 青草影院内射中出高潮-百度 | 午夜福利32集云播 | 日韩特黄特色大片免费视频 | 白丝女仆被强扒内裤 | 欧美日韩另类在线专区 | 狼群资源网中文字幕 | 他揉捏她两乳不停呻吟口述 | 国产亚洲精品香蕉视频播放 | 四虎影院网红美女 | 国产午夜精品一区理论片飘花 | 男男校园园bl文全肉高h寝室 | 脱jk裙的美女露小内内无遮挡 | 日韩熟女精品一区二区三区 | 真实国产乱子伦精品一区二区三区 | 久久精品国产亚洲AV天美18 | 亚洲综合无码一区二区 | 超碰在线视频地址 | 成人在线观看免费视频 | 两性色午夜视频免费国产 | 男人狂躁进女人免费视频公交 | 久久精品动漫网一区二区 | 天天操狠狠操夜夜操 | 国产精品69人妻无码久久久 | 久久精品国产亚洲AV麻豆欧美玲 | 99久久精品国产一区二区三区 | 先锋影音av无码第1页 | 亚洲视频在线看 | 在线播放午夜理论片 | 亚洲精品沙发午睡系列 | 巨乳中文无码亚洲 | 国产免费久久精品国产传媒 | 年轻的朋友4在线看中文字幕 |