mysql_fetch_assoc()用的是数据库中相应的字段名作为的key值(也就是数组下标)
如:filed['id']=1;
mysql_fetch_row()用的是自动生成的数字(从0开始依次生成)作为的key值(也就是数组下标)
如:filed[0]=1;
mysql_fetch_array()用的是自动生成的数字(从0开始依次生成)作为的key值(也就是数组下标),而且它还同时生成数据库中相应的字段名作为的key值(也就是数组下标)
如:
filed[0]=1,filed['id']=1;也就是说,mysql_fetch_array()将mysql_fetch_assoc()和mysql_fetch_row()查询到的结果合为了一体了。
mysql_fetch_object()与mysql_fetch_assoc()差不多。只是mysql_fetch_assoc()返回的是数组。mysql_fetch_object()返回的是object对象。
mysql_insert_id() 取得上一步 INSERT 操作产生的 ID。
mysql_result() 函数返回结果集中一个字段的值。
mysql_num_fields() 函数返回结果集中字段的数目。
mysql_affected_rows();返回前一次 MySQL 操作所影响的记录行数。
mysql_num_rows(mysql_query($sql))获得结果集中行的数目。
mysql_pconnect() 函数打开一个到 MySQL 服务器的持久连接。
# 使用Mysqli操作数据库的方法(连接,查询,事务回滚等)
<?php
header ( 'Content-Type:text/html; charset=utf-8;' );
$_mysqli = new mysqli('localhost','root','123456','testguest');
//数据库连接时发生的错误
if (mysqli_connect_errno()) {
echo '数据库连接出现了错误.错误的信息是:'.mysqli_connect_error();
exit();
}
//设置一下编码
$_mysqli->set_charset('utf8');
//创建一句SQL,获取数据库的表的数据
$_sql = "SELECT * FROM tg_user";
//创建一个结果集
$_result = $_mysqli->query($_sql);
//使用索引数组取值
//print_r($_result->fetch_row());
$_row = $_result->fetch_row();
....
echo $_row[3];
//遍历,下标很难记[3]
while (!!$_row = $_result->fetch_row()) {
echo $_row[3].'<br />';
}
.....
//我要看下我选择了多少行
echo $_result->num_rows;
//我影响了多少行呢
echo $_mysqli->affected_rows;
//求出表中有多少个字段
echo $_result->field_count;
//获取字段的名字
$_field = $_result->fetch_field();
echo $_field->name;
$_field = $_result->fetch_field();
echo $_field->name;
while (!!$_field = $_result->fetch_field()) {
echo $_field->name.'<br />';
}
//一次性取得所有的字段
$_fields = $_result->fetch_fields();
//echo $_fields[0]->name;
foreach ($_fields as $_field) {
echo $_field->name.'<br />';
}
//移动数据指针
$_result->data_seek(9);
$_row = $_result->fetch_row();
echo $_row[3];
//移动字段指针
$_result->field_seek(3);
$_field = $_result->fetch_field();
echo $_field->name;
//创建三个修改的SQL语句
$_sql .= "UPDATE tg_article SET tg_username='喀喀喀' WHERE tg_id=1;";
$_sql .= "UPDATE tg_flower SET tg_fromuser='喀喀喀' WHERE tg_id=1;";
$_sql .= "UPDATE tg_friend SET tg_fromuser='喀喀喀' WHERE tg_id=1";
//使用通知执行的方法
$_mysqli->multi_query($_sql);
//普通只能执行sql的方法是:$_mysqli->query($_sql);
//创建三条选择语句
$_sql .= "SELECT * FROM tg_photo;";
$_sql .= "SELECT * FROM tg_user;";
$_sql .= "SELECT * FROM tg_friend";
if ($_mysqli->multi_query($_sql)) {
//获取当前的结果集
$_result = $_mysqli->store_result();
print_r($_result->fetch_row());
echo '<br />';
//将结果集的指针移到下一条
$_mysqli->next_result();
$_result = $_mysqli->store_result();
if (!$_result) {
echo '第二条SQL语句有五!';
exit();
}
print_r($_result->fetch_row());
echo '<br />';
$_mysqli->next_result();
$_result = $_mysqli->store_result();
if (!$_result) {
echo '第三条SQL语句有五!';
exit();
}
print_r($_result->fetch_row());
} else {
echo '第一条SQL语句有误';
exit();
}
//设置关闭自动提交(手工提交)
$_mysqli->autocommit(false);
//创建两个SQL语句
$_sql .= "UPDATE tg_flower SET tg_flower=tg_flower-50 WHERE tg_id=1;";
$_sql .= "UPDATE tg_friend SET tg_state=tg_state+50 WHERE tg_id=1";
//执行多条SQL语句
//只要这两条SQL语句都成功了,就手工提交给数据库
//否则,就回滚,撤销之前的有效操作。
if ($_mysqli->multi_query($_sql)) {
//通过影响的行数,来判定SQL语句是否成功执行
//如果$_success是false说明sql语句有吴,那么就执行回滚,否则就手工提交
$_success = $_mysqli->affected_rows == 1 ? true : false;
//下移指针
$_mysqli->next_result();
$_success2 = $_mysqli->affected_rows == 1 ? true : false;
//如果两条都成功的话
if ($_success && $_success2) {
//执行手工提交
$_mysqli->commit();
echo '完美提交';
} else {
//执行回滚,撤销之前的所有操作
$_mysqli->rollback();
echo '所有操作归零!';
}
} else {
echo '第一条SQL语句有错误!';
}
//再开启自动提交
$_mysqli->autocommit(true);
mysql_fetch_assoc函数: php查询mysql数据库并将结果保存到数组
# mysql_fetch_assoc语法如下: array mysql_fetch_assoc (resource $Result_Set)
<?php
$UserName = 'abc';
$Password = '1234';
$DbHandle = mysql_connect ('localhost', $UserName, $Password);
if (!$DbHandle) {
die 'No database connection could be established.';
}
$DBName = 'w3db;
if (!mysql_select_db ($DBName, $DbHandle)) {
die 'Database could not be selected.';
}
$Query = "SELECT ISBN, Title, Author FROM articles";
$articles = mysql_query ($Query, $DbHandle));
while ($Row = mysql_fetch_assoc ($articles)) {
echo "ISBN = $Row['ISBN']<br />\n";
echo "Title = $Row['Title']<br />\n";
echo "Author = $Row['Author']<br />\n";
}
?># MySql数据库查询结果用表格输出
<?php
//在表格中显示表的数据,常用方式
function ShowTable($table_name){
$conn=mysql_connect("localhost","root","toor");
if(!$conn){
echo "连接失败";
}
mysql_select_db("test",$conn);
mysql_query("set names utf8");
$sql="select * from $table_name";
$res=mysql_query($sql,$conn);
$rows=mysql_affected_rows($conn);//获取行数
$colums=mysql_num_fields($res);//获取列数
echo "test数据库的"."$table_name"."表的所有用户数据如下:<br/>";
echo "共计".$rows."行 ".$colums."列<br/>";
echo "<table style='border-color: #efefef;' border='1px' cellpadding='5px' cellspacing='0px'><tr>";
for($i=0; $i < $colums; $i++){
$field_name=mysql_field_name($res,$i);
echo "<th>$field_name</th>";
}
echo "</tr>";
while($row=mysql_fetch_row($res)){
echo "<tr>";
for($i=0; $i<$colums; $i++){
echo "<td>$row[$i]</td>";
}
echo "</tr>";
}
echo "</table>";
}
ShowTable("test1");
?> //显示返回的记录集行数
if(mysql_num_rows($result)>0){
//如果返回的数据集行数大于0,则开始以表格的形式显示
echo "<table cellpadding=10 border=1>";
while($row=mysql_fetch_row($result)){
echo "<tr>";
echo "<td>".$row[0]."</td>";
echo "<td>".$row[1]."</td>";
echo "<td>".$row[2]."</td>";
echo "</tr>";
}
echo "</table>";
}
else{
echo "记录未找到!";
}
//释放记录集所占用的内存
mysql_free_result($result);
//关闭该数据库连接
mysql_close($connection);