php连接mysql提示Call to undefined function mysql_connect()

 更新时间:2016年11月25日 16:37  点击:2298
今天在windows中配置了php mysql环境,很高兴测试一段代码结果提示Call to undefined function mysql_connect()这证明数据库配置不成功哈。
 代码如下 复制代码

<?php

$conn = mysql_connect('localhost','root','password');

var_dump($conn);

?>

基本就是改配置文件php.ini 

首先要确保php.ini中extension_dir = "./ext",该设置是php引用dll的目录;

1.将php文件夹下libmysql.dll和php5ts.dll两个文件拷贝至windows目录下的system32下;或者在环境变量中增加D:php;D:phpext。这两个目录是php的安装目录和扩展dll的目录。
2.修改windows安装目录下的php.ini 去掉;extension=php_mysql.dll前面的分号;
3.extension_dir = "d:phpext (文件在PHP.INI中)。

你看看你的php.ini的配置找到

 代码如下 复制代码

extension=php_mysql.dll
extension=php_mysqli.dll把前面的分号去掉


我用的是apache,所以如果还这行的话,再看看主配置文件里的路径和引用都设置好了没有  PHPIniDir "PHP.INI的路径"   还要加一句  LoadModule*************的内容  这个网上都可以找得到。一般情况下到这里基本可以解决。

找到你的PHP根目录,找到两个文件 libmysql.dll和php5ts.dll 将之复制到system32下面。记住是PHP下面的。不是MYSQL

我们知道mssql不像php那样可以使用time哦,他生成的是时间格式DateTime这样就显示不对了,如下
 代码如下 复制代码

while( $row = sqlsrv_fetch_array( $result, SQLSRV_FETCH_ASSOC))
 {
   print_r($row['datetime']);//这个字段是mssql的时间格式

}

结果是

DateTime Object
(
    [date] => 2011-10-20 00:00:00
    [timezone_type] => 3
    [timezone] => Asia/Chongqing
)

解决办法

第一个方法:php文档开头定义ini_set(”mssql.datetimeconvert”,0);

第二个方法:修改php.ini,找到;mssql.datetimeconvert = On ,去掉前面的分号,修改on为off。

第三个方法:只有把mssql的时间字段用convert函数转换成字符串。

比如 SELECT *,convert(char,datetime字段,120) as str_datetime FROM 表名

这个str_datetime就是字符串了。第三个参数为120,刚好是我们需要的格式 yyyy-mm-dd hh:ii:ss

PHPEXCEL是一个用来生成excel的php插件,他可以很方便的对excel数据进行操作,如:生成excel,修改excel数据等等。

一、PHPEXCEL简介

PHPEXCEL提供了一系列的API,能够解析与生成excel,pdf之类的文档。

PHPEXCEL虽然强大,不过使用起来相对有些繁锁,如果需要输出较为复杂格式时,是一个不错的选择。可以到官方下载到源码。

二、PHPEXCEL部分函数

设置当前的工作簿,返回该工作簿对象:
$excelSheet = $excel->setActiveSheetIndex(0);

合并单元格,返回该单元格对象,以下示例即合并A列第一行与第二行所在单元格:

 代码如下 复制代码

$excelSheet->mergeCells('A1:A2');

设置单元格的值,参数:单元格名称,值:
$excelSheet->setCellValue('A1', '字符串内容');
$excelSheet->setCellValue('A2', 26); //数值
$excelSheet->setCellValue('A3', true); //布尔值
$excelSheet->setCellValue('A4', '=SUM(A2:A2)'); //公式

phpexcel用法介绍

 

 代码如下 复制代码

include ‘PHPExcel.php’;

  include ‘PHPExcel/Writer/Excel2007.php’;

  //或者include ‘PHPExcel/Writer/Excel5.php’; 用于输出.xls的

  创建一个excel

  $objPHPExcel = new PHPExcel();

  保存excel—2007格式

  $objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);

  //或者$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel); 非2007格式

  $objWriter->save(”xxx.xlsx”);

  直接输出到浏览器

  $objWriter = new PHPExcel_Writer_Excel5($objPHPExcel);

  header(”Pragma: public”);

  header(”Expires: 0″);

  header(”Cache-Control:must-revalidate, post-check=0, pre-check=0″);

  header(”Content-Type:application/force-download”);

  header(”Content-Type:application/vnd.ms-execl”);

  header(”Content-Type:application/octet-stream”);

  header(”Content-Type:application/download”);;

  header(’Content-Disposition:attachment;filename=”resume.xls”‘);

  header(”Content-Transfer-Encoding:binary”);

  $objWriter->save(’php://output’);

  

——————————————————————————————————————–

  设置excel的属性:

  

 代码如下 复制代码

创建人

  $objPHPExcel->getProperties()->setCreator(”Maarten Balliauw”);

  最后修改人

  $objPHPExcel->getProperties()->setLastModifiedBy(”Maarten Balliauw”);

  标题

  $objPHPExcel->getProperties()->setTitle(”Office 2007 XLSX Test Document”);

  题目

  $objPHPExcel->getProperties()->setSubject(”Office 2007 XLSX Test Document”);

  描述

  $objPHPExcel->getProperties()->setDescription(”Test document for Office 2007 XLSX, generated using PHP classes.”);

  关键字

  $objPHPExcel->getProperties()->setKeywords(”office 2007 openxml php”);

  种类

  $objPHPExcel->getProperties()->setCategory(”Test result file”);

  ——————————————————————————————————————–

  设置当前的sheet

  $objPHPExcel->setActiveSheetIndex(0);

  设置sheet的name

  $objPHPExcel->getActiveSheet()->setTitle(’Simple’);

  设置单元格的值

  $objPHPExcel->getActiveSheet()->setCellValue(’A1′, ‘String’);

  $objPHPExcel->getActiveSheet()->setCellValue(’A2′, 12);

  $objPHPExcel->getActiveSheet()->setCellValue(’A3′, true);

  $objPHPExcel->getActiveSheet()->setCellValue(’C5′, ‘=SUM(C2:C4)’);

  $objPHPExcel->getActiveSheet()->setCellValue(’B8′, ‘=MIN(B2:C5)’);

  合并单元格

  $objPHPExcel->getActiveSheet()->mergeCells(’A18:E22′);

  分离单元格

  $objPHPExcel->getActiveSheet()->unmergeCells(’A28:B28′);


 三、PHPEXCEL举例应用


整个代码如下(值得注意的是表头用了$orderCellData记录了每个商户编号的顺序,为了在表体把对应的数据取出):

 代码如下 复制代码

<<?php

   

    require_once '../../../libs/PHPExcel/Classes/PHPExcel.php';

    require_once '../../../libs/PHPExcel/Classes/PHPExcel/Writer/Excel5.php';

    include_once '../../../libs/PHPExcel/Classes/PHPExcel/IOFactory.php';

    include '../common/config.php';

    // 创建一个处理对象实例(此对象对于2003 2007是相同的)

    $objExcel = new PHPExcel();

   

    //设置属性(这段代码无关紧要,其中的内容可以替换为你需要的)

    $objExcel->getProperties()->setCreator("office 2003 excel");

    $objExcel->getProperties()->setLastModifiedBy("office 2003 excel");

    $objExcel->getProperties()->setTitle("Office 2003 XLS Test Document");

    $objExcel->getProperties()->setSubject("Office 2003 XLS Test Document");

    $objExcel->getProperties()->setDescription("Test document for Office 2003 XLS, generated using PHP classes.");

    $objExcel->getProperties()->setKeywords("office 2003 openxml php");

    $objExcel->getProperties()->setCategory("Test result file");

   

    //开始处理数据(索引从0开始)

    $objExcel->setActiveSheetIndex(0);

 

    $conn = mssql_connect($config['mssql']['host'],$config['mssql']['user'],$config['mssql']['password']);

    mssql_select_db($config['mssql']['dbname'],$conn);

   

    $tm=$_REQUEST['tm'];

   

    $sql = "exec HNow05_getTTSpace '','".$tm."','',1";

    $sql=mb_convert_encoding($sql,'GBK','UTF-8');

    $res=mssql_query($sql);

 

    $i=0;

    $k = array('站码','站名','河系','来报时间','水位','水势');

    $count = count($k);

    $arrs = array('A','B','C','D','E','F');

    //添加表头

    for($i=0;$i<$count;$i++){

       $objExcel->getActiveSheet()->setCellValue($arrs[$i]."1", "$k[$i]");

      

    }

   

    /*--------从数据库读取数据-------*/

    $i=0;

    while($arr=mssql_fetch_array($res))

    {

       $stcd = $arr["STCD"];

       $stnm = $arr["STNM"];

       $rvnm = $arr["RVNM"];

       $tm= $arr["TM"];

       $tdz= $arr["TDZ"];

        $tdptn= $arr["TDPTN"];

       if($tdptn=='6'){

           $tdptn='平';

       }else if($tdptn=='5'){

           $tdptn='涨';

       }else if($tdptn=='4'){

           $tdptn='落';

       }

 

       $u1=$i+2;

       $stnm=iconv("GBK","utf-8",$stnm);

       $rvnm=iconv("GBK","utf-8",$rvnm);

       $tm=iconv("GBK","utf-8",$tm);

 

       /*----------写入内容-------------*/

       $objExcel->getActiveSheet()->setCellValue('a'.$u1, "$stcd");

       $objExcel->getActiveSheet()->setCellValue('b'.$u1, "$stnm");

       $objExcel->getActiveSheet()->setCellValue('c'.$u1, "$rvnm");

       $objExcel->getActiveSheet()->setCellValue('d'.$u1, "$tm");

       $objExcel->getActiveSheet()->setCellValue('e'.$u1, "$tdz");

       $objExcel->getActiveSheet()->setCellValue('f'.$u1, "$tdptn");

 

       $i++;

    }

 

    /*----------设置单元格边框和颜色-------------*/

    $rows = mssql_num_rows($res);

    for($i=0;$i<($rows+1);$i++){

       for($j=0;$j<$count;$j++){

           $a = $i+1;

           $objExcel->getActiveSheet()->getStyle($arrs[$j].$a)->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);

           $objExcel->getActiveSheet()->getStyle($arrs[$j].$a)->getBorders()->getAllBorders()->getColor()->setARGB('FF00BBcc');

           //水平居中

           $objExcel->getActiveSheet()->getStyle($arrs[$j].$a)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

       }

    }

 

    // 高置列的宽度

    $objExcel->getActiveSheet()->getColumnDimension('A')->setWidth(10);

    $objExcel->getActiveSheet()->getColumnDimension('B')->setWidth(15);

    $objExcel->getActiveSheet()->getColumnDimension('C')->setWidth(15);

    $objExcel->getActiveSheet()->getColumnDimension('D')->setWidth(20);

    $objExcel->getActiveSheet()->getColumnDimension('E')->setWidth(10);

    $objExcel->getActiveSheet()->getColumnDimension('F')->setWidth(10);

   

    // 设置页眉和页脚。如果没有不同的标题奇数/即使是使用单头假定.

    $objExcel->getActiveSheet()->getHeaderFooter()->setOddHeader('&L&BPersonal cash register&RPrinted on &D');

    $objExcel->getActiveSheet()->getHeaderFooter()->setOddFooter('&L&B' . $objExcel->getProperties()->getTitle() . '&RPage &P of &N');

   

    // 设置页方向和规模

    $objExcel->getActiveSheet()->getPageSetup()->setOrientation(PHPExcel_Worksheet_PageSetup::ORIENTATION_PORTRAIT);

    $objExcel->getActiveSheet()->getPageSetup()->setPaperSize(PHPExcel_Worksheet_PageSetup::PAPERSIZE_A4);

   

    // 重命名表

    $objExcel->getActiveSheet()->setTitle('实时潮汐情况');

   

    // Set active sheet index to the first sheet, so Excel opens this as the first sheet

    $objExcel->setActiveSheetIndex(0);

   

    // Redirect output to a client’s web browser (Excel5)保存为excel2003格式

    //设置Excel的名字

    $excelName = '实时潮汐情况('.$tm.')';

    //$excelName = 'Excel_'.date("YmdHis");

    header('Content-Type: application/vnd.ms-excel');

    header('Cache-Control: max-age=0');

    header( 'Content-Disposition: attachment; filename='.iconv("utf-8", "GBK", $excelName).'.xls');

    $objWriter = PHPExcel_IOFactory::createWriter($objExcel, 'Excel5');

    $objWriter->save('php://output');


    exit;


?>

昨天在使用phpmyadmin连接mysql时出现了#2002 – 服务器没有响应 (或者本地 MySQL 服务器的套接字没有正确配置),但我利用php连接没有问题如

 代码如下 复制代码

<?php  
$link=mysql_connect("127.0.0.1","root","password");  
if (!$link) echo "connect error";  
else echo "connect ok";  
?>

后来想相MySQL数据库服务器的地址应该改成127.0.0.1,

具体方法:

打开我们刚才拷贝到phpMyAdmin目录下的config.inc.php 中

找到这句话:

 代码如下 复制代码

$cfg['Servers'][$i]['host'] = 'localhost';

改成

$cfg['Servers'][$i]['host'] = '127.0.0.1';

这样即可了 ,导致这个问题的原因我觉得应该是host文件解析有问题,大家处理一应该就好了。

php配置mysql与怎么测试配置数据库成功 有需要的朋友可参考一下。

如果你是初次配置 php mysql apache的话,我们要怎么测试php连接数据库成功了,只要创建一个test.php文件,然后把下面代码保存到文件。

 代码如下 复制代码

<?php
$link=mysql_connect("localhost","root","12345"); //12345改成你的mysql密码
if(!$link) echo "失败!";
else echo "成功!";
mysql_close();
?>

在浏览器打开 http://localhost/test.php

如果输入

成功就说明你的配置成功了,如果失败我们可以在mysql_connect("localhost","root","12345") or die( mysql_error());这样就会有错误提示哦。

如果提示mysql_connect函数未定义,我们可以在php.ini中如下图

;extension=php_mysql.dll
;extension=php_mysqli.dll

把前面的;去了

extension=php_mysql.dll
extension=php_mysqli.dll

然后重启apache即可

[!--infotagslink--]

相关文章