Mysql查询创建表不适用于php
我正在尝试将两个表结构复制到一个新数据库中。 我使用了一个自己生成SQL命令的函数:当我在phpmyadmin上执行代码时,代码会被执行,但当我通过PHP执行时,它不会执行 怎么可能 sql命令如下所示:Mysql查询创建表不适用于php,php,mysql,Php,Mysql,我正在尝试将两个表结构复制到一个新数据库中。 我使用了一个自己生成SQL命令的函数:当我在phpmyadmin上执行代码时,代码会被执行,但当我通过PHP执行时,它不会执行 怎么可能 sql命令如下所示: CREATE TABLE `tabella_1` ( `campo1` int(11) NOT NULL AUTO_INCREMENT, `campo2` varchar(100) COLLATE latin1_general_ci NOT NULL, `campo_3`
CREATE TABLE `tabella_1` (
`campo1` int(11) NOT NULL AUTO_INCREMENT,
`campo2` varchar(100) COLLATE latin1_general_ci NOT NULL,
`campo_3` int(11) NOT NULL,
PRIMARY KEY (`campo1`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci;
CREATE TABLE `tabella_2` (
`campo1` int(11) NOT NULL DEFAULT '0',
`campo2` varchar(100) COLLATE latin1_general_ci NOT NULL,
`campo_3` int(11) NOT NULL,
PRIMARY KEY (`campo1`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci;
谢谢使用您的数据库连接详细信息更新此代码:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "CREATE TABLE `tabella_1` ( `campo1` int(11) NOT NULL AUTO_INCREMENT, `campo2` varchar(100) COLLATE latin1_general_ci NOT NULL, `campo_3` int(11) NOT NULL, PRIMARY KEY (`campo1`) ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci";
if ($conn->query($sql) === TRUE) {
echo "Table 1 created successfully";
} else {
echo "Error creating table: " . $conn->error;
}
// sql to create table
$sql2 = "CREATE TABLE `tabella_2` ( `campo1` int(11) NOT NULL DEFAULT '0', `campo2` varchar(100) COLLATE latin1_general_ci NOT NULL, `campo_3` int(11) NOT NULL, PRIMARY KEY (`campo1`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci";
if ($conn->query($sql2) === TRUE) {
echo "Table 2 created successfully";
} else {
echo "Error creating table: " . $conn->error;
}
$conn->close();
?>
我明白了
我在函数中放入了一个数组(),它就工作了
祝大家好运 PHP中发生了什么?你用的是什么司机?你能展示一下PHP的使用情况吗?你有没有试着逐个运行查询,也许这会导致mysql驱动程序出现问题?这就是代码$sql2是我在$connessione=mysql\u connect(“,”根“,”)之前编写的查询;mysql\u select\u db(“alternanza”.$anno);if(mysql_query($sql2,$connessione)){echo“Il-database alternanza_uo.”$anno.“stato aggiornato!”;echo(”);else{echo(“error-nell'aggiornamento del database alternanza_o.”-“.mysql_error()”;echo(”);mysql_close($connessione);根据PHP手册,mysql\u查询(无论如何都不应该使用)不会执行多个查询<代码>不支持多个查询
-在同一“行”中有2+条语句。PHP的mysql驱动程序不允许在单个query()
调用中使用多个语句。这是一种针对某种形式的感谢的廉价防御机制。。。但还是有一个问题。。。sql由“SHOW CREATE TABLE”命令生成。。。所以它在输出中进行了2次查询。。。如何获取sql代码来创建表结构副本1 by 1?