PHP连接mysql 数据库,一般来说分为普通方法和面向对象两种方法。在此,进行一个简单的讲解。
方法一:普通方法(面向过程)
首先,我先做出如下假设。
$username=your_name; $userpass=your_pass; $dbhost=localhost; $dbdatabase=your_database;
下面是关键步骤:
1 //生成一个连接 2 $db_connect=mysql_connect($dbhost,$username,$userpass) or die("Unable to connect to the MySQL!"); 3 4 //选择一个需要操作的数据库 5 mysql_select_db($dbdatabase,$db_connect); 6 7 //执行MySQL语句 8 $result=mysql_query("SELECT id,name FROM user"); 9 10 //提取数据 11 $row=mysql_fetch_row($result);
代码注释已经说明了一切。不过这里还需要做一些补充。
①在mysql_connect()、mysql_select_db()等函数之前使用@(错误控制运算符),可以忽略掉系统产生的错误信息,然后我们用die()来自定义错误信息;
②提取数据的时候,除了上面的mysql_fetch_row,常见的还有mysql_fetch_assoc和mysql_fetch_array,具体差别请查阅PHP Manual;
③对于mysql_query()函数的返回值,如果执行的语句有返回值(如SELECT、SHOW、DESCRIBE等),则返回相应数据(成功时)或FALSE(失败时);如果执行的语句没有返回值(如DELETE、DROP、INSERT、UPDATE等),则返回TRUE(成功时)或FALSE(失败时)。
方法二:面向对象方法
其实这种方法和普通方法非常类似,只是把相应的函数换成了面向对象方法,直接看代码。
1 $db=new mysqli($dbhost,$username,$userpass,$dbdatabase); 2 if(mysqli_connect_error()){ 3 echo 'Could not connect to database.'; 4 exit; 5 } 6 7 $result=$db->query("SELECT id,name FROM user"); 8 $row=$result->fetch_row();
这里用到的是mysqli,意思就是mysql的扩展,既可以通过面向过程的方式也可以通过面向对象的方式与数据库进行交互,唯一不同的是调用函数(对象方法)的方式不一样。