Mysql数据库导出为Excel(ODBC驱动)
- PHP code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> <?php date_default_timezone_set('Asia/Shanghai'); /* *@author:jinger7281@gmail.com *在本程序不侵犯任何公司或个人权利的情况下: *本程序遵循GPL v2许可证分发,详情查看http://www.gnu.org/copyleft/lesser.html *如果本程序已经使用他人专利,本程序将按照专利持有人许可进行使用 *如果本程序侵犯了您的专利,请及时联系作者(上方邮箱即可),本人及时会做出更正声明,如有不便敬请谅解。 *本类实现: *只要填写正确的mysql数据库、表信息自动将Mysql数据库的内容导出为Excel文件,一键完成,需要ODBC的支持,此为Windows版本 *注意:填写的时候Excel文件只需要填写文件名即可,导出Excel为是2003版本。 * 因为本人水平有限,必须按照示例程序的样本填写完毕方可顺利执行 * 本版本中存在已知瑕疵: * 1、Mysql数据库出错会输出错误信息。Release版本请自行删除保证服务器信息安全 * 2、odbc连接部分没有做出错误处理,Release版本请自行添加错误处理部分(mysql一样) */ class mysql2Xls{ private $currDir; //当前目录名使用dirname(__FILE__)获取 private $srcData; //Mysql获取的数据数组,此为2维数组 private $srcColumn; //Mysql数据库的列名,为了将列名对应到Excel文件中的第一行,此属性为1维数组 public $xlsName; //Excel文件的文件名,不需要添加后缀,后缀是自动添加的,如果需要设置后缀,请在setXlsName函数中更改后缀 private $host; //本行一下五行为Mysql的连接设置 private $userName; private $pwd; private $dbName; private $tbName; public function __construct(){ $this->currDir = dirname(__FILE__); } /* 获取Mysql的列名称 */ public function getSrcColumn(){ $handle = @mysql_connect($this->host,$this->username,$this->pwd); $this->srcColumn = array(); if(is_bool($handle)){ echo "====**====<br>"; echo "Mysql连接出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } $ret = @mysql_select_db($this->dbName,$handle); if($handle == FALSE){ echo "====**====<br>"; echo "Mysql选择数据库出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } $ret = @mysql_query('describe '.$this->tbName,$handle); if(is_bool($ret)){ echo "====**====<br>"; echo "Mysql语句执行出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } while(($data = mysql_fetch_array($ret)) != FALSE){ array_push($this->srcColumn,$data['Field']); } mysql_free_result($ret); mysql_close($handle); return $this->srcColumn; } /* 获取指定的Mysql数据库表中的内容 */ public function getSrcData(){ $handle = @mysql_connect($this->host,$this->username,$this->pwd); $this->srcData = array(); if(is_bool($handle)){ echo "====**====<br>"; echo "Mysql连接出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } $ret = @mysql_select_db($this->dbName,$handle); if($handle == FALSE){ echo "====**====<br>"; echo "Mysql选择数据库出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } $ret = @mysql_query('select * from '.$this->tbName,$handle); if(is_bool($ret)){ echo "====**====<br>"; echo "Mysql语句执行出错.<br>文件:".(__FILE__)." <br>行号:".(__LINE__)."<br>错误:".mysql_error(); echo "<br>====**====<br>"; exit(0); } while(($data = mysql_fetch_array($ret)) != FALSE){ array_push($this->srcData,$data); } mysql_free_result($ret); mysql_close($handle); return $this->srcData; } /* 主力部分 将Mysql数据库中的内容导出为Excel文件 */ public function m2Xls(){ $handle = odbc_connect("Driver={MicroSoft Excel Driver (*.xls)};READONLY=false;CREATE_DB=\"".$this->xlsName."\";Dbq=".$this->xlsName,"",""); $sql = 'create table '.$this->tbName.'('; foreach($this->srcColumn as $value){ $sql .= ($value." text,"); } $sql = substr($sql,0,strlen($sql)-1); $sql .= ")"; $ret = odbc_exec($handle,$sql); //以上内容是创建一个Excel文件 并将Mysql的列转移到Excel文件中去。 foreach($this->srcData as $value){ $sql = 'insert into ['.$this->tbName.'$] values('; for($i=0;$i<count .="iconv("UTF-8","GB2312","'".$value[$i]."',");" substr echo odbc_exec public function setmysqlargs>host = $host; $this->username = $username; $this->pwd = $pwd; $this->dbName = $dbName; $this->tbName = $tbName; } /* 设置Excel数据库的名称 */ public function setXlsName($xlsName){ $this->xlsName = $this->currDir."\\".$xlsName.".xls"; return $this->xlsName; } } /*以下部分是测试功能的,可删除*/ header("Content-Type:text/html;charset=UTF-8"); $mysql2xls = new mysql2Xls(); $mysql2xls->setMysqlArgs('localhost','root','******','others','zhuifeng'); $mysql2xls->setXlsName('test'); $mysql2xls->getSrcColumn(); $mysql2xls->getSrcData(); $mysql2xls->m2Xls(); ?> <div class="clear"> </div></count>

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增強codemodocultion,可驗證性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

選擇DependencyInjection(DI)用於大型應用,ServiceLocator適合小型項目或原型。 1)DI通過構造函數注入依賴,提高代碼的測試性和模塊化。 2)ServiceLocator通過中心註冊獲取服務,方便但可能導致代碼耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)啟用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替換loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化進行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版
中文版,非常好用

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具