起步
因为mysql衔接形式被破除,正在php7中要应用mysql_connect()还需求额定下载组件。
应用mysqli有面向进程以及面向工具两种形式。
mysqli提供了三个类:
● mysqli 衔接相干的
● mysqli_result 解决后果集
● mysqli_stmt 预解决类
数据库衔接
<?php $db_host = 'localhost'; $db_name = 'test'; $db_user = 'root'; $db_pwd = ''; //面向工具形式 $mysqli = new mysqli($db_host, $db_user, $db_pwd, $db_name); //面向工具的昂视屏蔽了衔接孕育发生的谬误,需求经过函数来判别 if(mysqli_connect_error()){ echo mysqli_connect_error(); } //设置编码 $mysqli->set_charset("utf8");//或许 $mysqli->query("set names 'utf8'") //封闭衔接 $mysqli->close(); //面向进程形式的衔接形式 $mysqli = mysqli_connect($db_host, $db_user, $db_pwd, $db_name); //判别能否衔接胜利 if(!$mysqli ){ echo mysqli_connect_error(); } //封闭衔接 mysqli_close($mysqli); ?>
数据库查问
通用:执行sql语句均可用query(sql),执行失败会前往false,select胜利则前往后果集工具,其余前往true,只需没有是false就阐明sql语句执行胜利了。
<?php //无后果集示例 $sql = "insert into table_name (`name`, `address`) values ('xiaoming', 'adddddrrreess')"; $result = $mysqli->query($sql); //或许 $sql = "delete from table_name where name='xiaoming'"; $result = $mysqli->query($sql); if($result === false){ echo $mysqli->error; echo $mysqli->errno; } //影响条数 echo $mysqli->num_rows; //拔出的id echo $mysqli->insert_id; $mysqli->close();
有后果集
<?php $sql = "select * from table_name"; $result = $mysqli->query($sql); if($result === false){//执行失败 echo $mysqli->error; echo $mysqli->errno; } //行数 echo $result->num_rows; //列数 字段数 echo $result->field_count; //猎取字段信息 $field_info_arr = $result->fetch_fields(); //挪动记载指针 //$result->data_seek(1);//0 为重置指针到肇始 //猎取数据 while($row = $result->fetch_assoc()){ echo $row['name']; echo $row['address']; } //也可一次性猎取一切数据 //$result->data_seek(0);//假如后面有挪动指针则需重置 $data = $result->fetch_all(MYSQLI_ASSOC); $mysqli->close();
预解决示例
预解决能无效的避免sql注入的孕育发生,mysqli_stmt是预解决类
<?php $sql = "insert inro table_name ('name','address') values (?,?)"; //取得预解决工具 $stmt = $mysqli->prepare($sql); //绑定参数 第一个参数为绑定的数据类型 /* i:integer 整型 d:double 浮点型 s:string 字符串 b:a blob packets blob数据包 */ $name = "xiaoming"; $address = "adddressss"; $stmt->bind_param("ss", $name, $address);//绑按时应用变量绑定 //执行预解决 $stmt->execute(); /* //可从新绑定 屡次执行 $stmt->bind_param("ss", $name, $address); $stmt->execute(); */ //拔出的id 屡次拔出为最初id echo $stmt->insert_id; //影响行数 也是最初一次执行的 echo $stmt->affected_rows; //谬误号 echo $stmt->errno; //谬误信息 echo $stmt->error; //封闭 $stmt->close(); $mysqli->close(); 上面示例select的预解决 //正文局部省略 $sql = "select * from table_name where id<?"; $stmt = $mysqli->prepare($sql); $id = 30; $stmt->bind_param("i", $id); $stmt->execute(); //猎取后果集 $result = $stmt->get_result();//后果集取后的操作就以及以前同样了 //猎取一切数据 $data = $result->fetch_all(MYSQLI_ASSOC); $result->close(); $mysqli->close();
一次执行多条sql语句multiquery(没有保举),执行后果没有是后果集,affectd_rows是最初影响的条数
<?php $sql_arr = array( "insert into table_name (`name`,`address`) values ('xiaoming','a')", "insert into table_name (`name`,`address`) values ('xiaohong','a')", 'delete from table_name where id=23', ); $sql = implode(';', $sql_arr); $result = $mysqli->multi_query($sql); if($result === false){ echo $mysqli->error; } $mysqli->close();
更多的PHP相干常识,请拜访PHP中文网!
以上就是PHP mysqli操作数据库的具体内容,更多请存眷资源魔其它相干文章!
标签: php php开发教程 php开发资料 php开发自学
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
抱歉,评论功能暂时关闭!