php mysql, mysql_query() expects parameter 2 to be resource

/*这是可行的<html><head></head><body><?$conn=mysql_connect('localhost','root','f3r5tqfp')o... /*这是可行的
<html>
<head>
</head>
<body>
<?
$conn = mysql_connect('localhost','root','f3r5tqfp')or die('Could not connect ' .mysql_error());
echo 'Connected successfully';
if (mysql_query("create database my_db",$conn))
{
echo "Database created";
}
else
{
echo "Error creating database: " . mysql_error();
}
}
?>
</body>
</html>
*/

当我修改成这样,mysql_query怎麼我把原先my_db转为形参就发生问题
Warning: mysql_query() expects parameter 2 to be resource, null given in /Applications/XAMPP/xamppfiles/htdocs/dropDownMenu/css80.php on line 10
Error creating database:

<html>
<head>
</head>
<body>
<?
$conn = mysql_connect('localhost','root','f3r5tqfp')or die('Could not connect ' .mysql_error());
echo 'Connected successfully';
function createDB($db)
if (mysql_query("create database $db",$conn))
{
echo "Database created";
}
else
{
echo "Error creating database: " . mysql_error();
}
}
createDB('my_db');
?>
</body>
</html>
展开
 我来答
百度网友5723daf2d
推荐于2018-05-17 · TA获得超过122个赞
知道小有建树答主
回答量:204
采纳率:0%
帮助的人:261万
展开全部
变量作用域的问题。

$conn在function中的时候是局部变量,且未定义,所以会报那个错误。
可以这样写
<?
$conn = mysql_connect('localhost','root','f3r5tqfp')or die('Could not connect ' .mysql_error());
echo 'Connected successfully';
function createDB($db,$conn)
if (mysql_query("create database $db",$conn))
{
echo "Database created";
}
else
{
echo "Error creating database: " . mysql_error();
}
}
createDB('my_db',$conn);
?>

Ps: 如果db是外界传递过来的名字,建议进入function后执行sql之前 对$db做下check,防止这里注入
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
gwbnet
2012-10-17 · TA获得超过894个赞
知道小有建树答主
回答量:350
采纳率:100%
帮助的人:222万
展开全部
确认下出错原因:
if (mysql_query("create database $db",$conn)),这一句,将这里的$db直接换成常量,执行一下。应该是$db变量的使用问题。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式