登录  /  注册

mysql连接成功但提示mysql_query未定义

php中文网
发布: 2016-06-23 14:28:26
原创
3067人浏览过

mysql php

情景描述:
查询两台服务器上的数据库,提取用户数据。
① 将数据列表显示,已成功
<?php/* Filename[book.php] */require_once("header.php");#连接另一台数据库$mysql_ = new MySqlList();#获取通讯录$addrPersons= empty($_SESSION['uid'])?null:$mysql->getAddrPerson($_SESSION['uid']);	//个人//个人通讯录$dataPers = (empty($addrPersons['addrperson']))?array():json_decode(base64_decode($addrPersons['addrperson']),true);//$addrPersons  array();#获取公司通讯录$stafflists = $mysql->getDomainUserList($domain);$stafflists_ = $mysql_->getDomainUserList($domain);debug(count($stafflists));  //29debug(count($stafflists_)); //57
登录后复制

② 提供搜索,在单独的搜索页再次提取两台服务器上的用户数据,并根据关键词进行过滤。
此时PHP终止,Fatal error: Call to undefined function mysql_query()

<?php/* Filename[book_search.php] */date_default_timezone_set('PRC');Header("content=text/html; charset=UTF-8");session_start();require_once (dirname(__FILE__) . "/../classes/action/initialize.php");require_once (dirname(__FILE__) . "/../classes/mode/xmlparse.inc");require_once (dirname(__FILE__) . "/../classes/mode/mysql_mode_class.php");require_once (dirname(__FILE__) . "/../classes/mode/mysql_list_class.php");#连接本地数据库$mysql = new MySqlModeMail();#连接另一台数据库//$othersql = new MySqlList();#获取通讯录$addrPersons= empty($_SESSION['uid'])?null:$mysql->getAddrPerson($_SESSION['uid']);	//个人$dataPers = (empty($addrPersons['addrperson']))?array():json_decode(base64_decode($addrPersons['addrperson']),true);//$addrPersons  null#获取公司通讯录$stafflists = $mysql->getDomainUserList($domain);//$stafflists_ = $othersql->getDomainUserList($domain);debug($stafflists);exit;//debug($stafflists_);
登录后复制


可能是哪一步出错?


回复讨论(解决方案)

在你贴出的代码中,没有看到 mysql_query
你只能根据错误信息指示的行号排查错误

php代码中数据库的密码要和电脑里的数据库中的密码一样

require_once (dirname(__FILE__) . "/../classes/mode/mysql_mode_class.php");require_once (dirname(__FILE__) . "/../classes/mode/mysql_list_class.php");//这两行也有在header.php中包含//这两个类中的执行函数是一样的 class MySqlList {	//sql params	public $server;	public $username;	public $password;	public $database;	public $code;	function MySqlList(){		global $webpost;//		include("xmlparse.inc");		$sqlist = parse_xml_config($webpost['path']['sqlist'],"sqlist");		if(!empty($sqlist) && is_array($sqlist)){			foreach($sqlist['list'] as $list){				if(strcmp($list['server'],$_SERVER['SERVER_ADDR'])){					$config = $list;				}			}//end for		}//end if		if(empty($config))			die("读取MySql配置出错。");		$this->server = $config['server'];		$this->username = $config['username'];		$this->password = $config['password'];		$this->database = $config['database'];	} 	//connect sql 	function connect(){		$connect = mysql_connect($this->server, $this->username, $this->password);		if (!$connect){			die("服务器连接失败:".mysql_error());		}		$conn = mysql_select_db($this->database,$connect) or die("数据库连接失败!<br/>");		mysql_query("set names utf8");		return $connect;	}	//execute sql	function querySql($sql,$array=2,$fail=false,$succe=false,$suc_href=false,$type=MYSQL_ASSOC){ 		global $webpost;		$result = mysql_query($sql,$this->connect()); //提示在这里终止		if(!$result)     		 die("SQL: {$sql} <br>Error: " . mysql_error() );		if (mysql_affected_rows() >0){//			write_sys_log("success SQL:".$sql);			switch($array){				case 1:					$arry = array();					while($arr = @mysql_fetch_array($result,$type)){						array_push($arry,$arr);					}					return $arry;				case 2:					$arr = @mysql_fetch_array($result,$type);					return $arr;				default:					return 1;			}		}elseif(mysql_affected_rows() == 0 && !mysql_errno()){//			write_sys_log("empty SQL:".$sql);			return false;		}elseif(mysql_errno()){//			write_sys_log("failed SQL:".$sql);			return 0;		}		mysql_close();	}	#获取另一台数据库的用户数据 	function getDomainUserList($domain){ 		$sql = "SELECT m.id,m.did,m.code,username,realname,domain FROM table_a m ".			"JOIN table_b d ON m.did=d.id WHERE domain='{$domain}'";		return $this->querySql($sql,1); 	} }
登录后复制

思路上大概哪里有问题?

除 mysql_query 外,其他 mysql 族函数均没有报错
只能说 mysql 扩展安装(编译)错误

但是,我在提取用户数据后,是可以列表显示的。
只是在单独的搜索页却出现这个问题。

你提供的信息太少
不排除个别应用中单词拼写错误

终于排查出来了,是因为单独的搜索页没有获取到$_SESSION。
但是我加session_start()了,而且是由前面的列表页,通过$.ajax获取搜索页的内容。
为什么搜索页的$_SESSION是空的?

在 $_SESSION 为空的程序中检查 get_included_files 返回的文件列表

通常 session_start() 宜放在全局的公共文件中
况且 php 5.4 还会检查该函数是否被执行过,如执行过将会产生警告信息

问题解决了。
原因:在搜索页的包含页中,header()和session_start()的位置搞错了。把包含页中的header注掉就好了。

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号