Rumah pembangunan bahagian belakang tutorial php Mysql数据库导出替Excel(ODBC驱动)

Mysql数据库导出替Excel(ODBC驱动)

Jun 13, 2016 am 10:42 AM
gt mysql quot this

Mysql数据库导出为Excel(ODBC驱动)

PHP code
<!--Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--><?php date_default_timezone_set('Asia/Shanghai');        /*     [email&#160;protected]:[email&#160;protected]     *在本程序不侵犯任何公司或个人权利的情况下:     *本程序遵循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>
Salin selepas log masuk
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MySQL: Kemudahan Pengurusan Data untuk Pemula MySQL: Kemudahan Pengurusan Data untuk Pemula Apr 09, 2025 am 12:07 AM

MySQL sesuai untuk pemula kerana mudah dipasang, kuat dan mudah untuk menguruskan data. 1. Pemasangan dan konfigurasi mudah, sesuai untuk pelbagai sistem operasi. 2. Menyokong operasi asas seperti membuat pangkalan data dan jadual, memasukkan, menanyakan, mengemas kini dan memadam data. 3. Menyediakan fungsi lanjutan seperti menyertai operasi dan subqueries. 4. Prestasi boleh ditingkatkan melalui pengindeksan, pengoptimuman pertanyaan dan pembahagian jadual. 5. Sokongan sokongan, pemulihan dan langkah keselamatan untuk memastikan keselamatan data dan konsistensi.

Bolehkah saya mengambil kata laluan pangkalan data di Navicat? Bolehkah saya mengambil kata laluan pangkalan data di Navicat? Apr 08, 2025 pm 09:51 PM

Navicat sendiri tidak menyimpan kata laluan pangkalan data, dan hanya boleh mengambil kata laluan yang disulitkan. Penyelesaian: 1. Periksa Pengurus Kata Laluan; 2. Semak fungsi "Ingat Kata Laluan" Navicat; 3. Tetapkan semula kata laluan pangkalan data; 4. Hubungi pentadbir pangkalan data.

Cara Membuat Premium Navicat Cara Membuat Premium Navicat Apr 09, 2025 am 07:09 AM

Buat pangkalan data menggunakan Navicat Premium: Sambungkan ke pelayan pangkalan data dan masukkan parameter sambungan. Klik kanan pada pelayan dan pilih Buat Pangkalan Data. Masukkan nama pangkalan data baru dan set aksara yang ditentukan dan pengumpulan. Sambung ke pangkalan data baru dan buat jadual dalam penyemak imbas objek. Klik kanan di atas meja dan pilih masukkan data untuk memasukkan data.

Cara menyalin jadual di mysql Cara menyalin jadual di mysql Apr 08, 2025 pm 07:24 PM

Menyalin jadual di MySQL memerlukan membuat jadual baru, memasukkan data, menetapkan kunci asing, menyalin indeks, pencetus, prosedur tersimpan, dan fungsi. Langkah -langkah khusus termasuk: mewujudkan jadual baru dengan struktur yang sama. Masukkan data dari jadual asal ke dalam jadual baru. Tetapkan kekangan utama asing yang sama (jika jadual asal mempunyai satu). Buat indeks yang sama. Buat pencetus yang sama (jika jadual asal mempunyai satu). Buat prosedur atau fungsi yang disimpan yang sama (jika jadual asal digunakan).

Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Apr 08, 2025 pm 09:18 PM

Navicat untuk MariaDB tidak dapat melihat kata laluan pangkalan data secara langsung kerana kata laluan disimpan dalam bentuk yang disulitkan. Untuk memastikan keselamatan pangkalan data, terdapat tiga cara untuk menetapkan semula kata laluan anda: Tetapkan semula kata laluan anda melalui Navicat dan tetapkan kata laluan yang kompleks. Lihat fail konfigurasi (tidak disyorkan, risiko tinggi). Gunakan alat baris perintah sistem (tidak disyorkan, anda perlu mahir dalam alat baris arahan).

Cara Melaksanakan SQL di Navicat Cara Melaksanakan SQL di Navicat Apr 08, 2025 pm 11:42 PM

Langkah -langkah untuk melaksanakan SQL di Navicat: Sambungkan ke pangkalan data. Buat tetingkap editor SQL. Tulis pertanyaan SQL atau skrip. Klik butang Run untuk melaksanakan pertanyaan atau skrip. Lihat hasilnya (jika pertanyaan dilaksanakan).

Cara Membuat Sambungan Baru ke MySQL di Navicat Cara Membuat Sambungan Baru ke MySQL di Navicat Apr 09, 2025 am 07:21 AM

Anda boleh membuat sambungan MySQL baru di Navicat dengan mengikuti langkah -langkah: Buka aplikasi dan pilih Sambungan Baru (Ctrl N). Pilih "MySQL" sebagai jenis sambungan. Masukkan nama host/alamat IP, port, nama pengguna, dan kata laluan. (Pilihan) Konfigurasikan pilihan lanjutan. Simpan sambungan dan masukkan nama sambungan.

Navicat tidak dapat menyambung ke MySQL/MariaDB/PostgreSQL dan pangkalan data lain Navicat tidak dapat menyambung ke MySQL/MariaDB/PostgreSQL dan pangkalan data lain Apr 08, 2025 pm 11:00 PM

Alasan Biasa Mengapa Navicat tidak dapat menyambung ke pangkalan data dan penyelesaiannya: 1. Periksa status berjalan pelayan; 2. Periksa maklumat sambungan; 3. Laraskan tetapan firewall; 4. Konfigurasi akses jauh; 5. menyelesaikan masalah rangkaian; 6. Periksa keizinan; 7. Memastikan keserasian versi; 8. menyelesaikan masalah lain.

See all articles