mysql和pdo原生操作

mysql:

//连接操作
$link = mysql_connect($host,$username,$password);
mysql_select_db('user',$link);

//insert,update,delete操作
$sql = 'insert into user(name,age) values('jack',18)';
$result = mysql_query($sql);//执行成功返回true
if($result && mysql_affected_rows() > 0){
	echo '插入成功';
}
mysql_close($link);

//查询操作
$sql = 'select name,age from user limit 5';
$result = mysql_query($sql);
//mysql_fetch_row将一行记录返回为索引数组,mysql_fetch_assoc返回关联数组
while($raw = mysql_fetch_assoc($result)){
	//...
}
mysql_free_result();
mysql_close($link);

pdo

  • 关于pdo的长连接
//PDO对象的方法
errorCode();//获取错误码
errorInfo();//获取错误信息
exec();//执行一条sql语句,一般是update,insert和delete,返回影响的行数
query();//执行一条select语句,返回PDOStatement对象,然后可以调用PDOStatement对象的fetch或者fetchAll方法
lastInsertId();//获取插入到表中最后一条记录的主键值
prepare();//准备要执行的sql
beginTransaction();//开启事物
commit();//提交事物
rollback();//回滚事物



//PDOStatement对象的方法
bindParam();
execute();
fetch();//一行数据,PDO::FETCH_NUM->索引数组,PDO::FETCH_ASSOC->关联数组
fetchAll();//二维数组
rowCount();
setFetchMode();

$pdo = new PDO('mysql:dbname=edison;host=127.0.0.1','username','password');
$stmt = $pdo->prepare('select * from user where id = ?');
$stmt->bindParam(1,$id);
$id = 1;
$stmt->execute();
while($data = $stmt->fetch(PDO::FETCH_ASSOC)){
	//...
}
$id = 2;
$datas = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach($datas as $data){
	echo $data['name'];
}














你可能感兴趣的:(php)