Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/58.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql查询创建表不适用于php_Php_Mysql - Fatal编程技术网

Mysql查询创建表不适用于php

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`

我正在尝试将两个表结构复制到一个新数据库中。 我使用了一个自己生成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` 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?