php数据库操作--PDO方式

PDO方式(project data object)
连接:

<?php $servername = "localhost"; $username = "root"; $password = "123456"; try{ $conn = new PDO("mysql:host=$servername;",$username,$password); echo "连接成功"; } catch(PDOException $e) { echo $e->getMessage(); } ?>

关闭连接:

脚本执行完后会自动关闭。
手动关闭:
$conn = null;

创建数据库:

<?php $servername = "localhost"; $username = "username"; $password = "password"; try { $conn = new PDO("mysql:host=$servername;",$username,$password); //设置PDO错误模式为异常 $conn ->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql = "CREATE DATABASE test"; $conn -> exec($sql); echo "创建数据库成功!"; } catch(PDOException $e) { echo $sql . $e->getMessage(); } $conn = null; ?>

创建表:

try {
c o n n = n e w P D O ( &quot; m y s q l : h o s t = conn = new PDO(&quot;mysql:host= conn=newPDO("mysql:host=servername;dbname= d b n a m e &quot; , dbname&quot;, dbname",username,$password);
$conn ->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

$sql = "sql语句";
$conn->exec($sql);
echo "成功";

} catch(PDOException $e) {
echo $sql . $e->getMessage();
}
$conn = null;

插入数据:

try {
c o n n = n e w P D O ( &quot; m y s q l : h o s t = conn = new PDO(&quot;mysql:host= conn=newPDO("mysql:host=servername;dbname= d b n a m e &quot; , dbname&quot;, dbname",username,$password);
$conn ->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

$sql = "INSERT INTO test(username,age,sex) VALUE('Aicmo','21','1')";

$conn->exec($sql);
echo "成功";

} catch(PDOException $e) {
echo $sql . $e->getMessage();
}
$conn = null;

插入多条数据:

//开始事务
$conn -> beginTransaction();
//sql语句
$conn->exec(“sql插入语句”);
$conn->exec(“sql插入语句”);
$conn->exec(“sql插入语句”);

//提交事务
$conn->commit();
echo “成功”;

catch(PDOException $e) {
$conn->rollback(); //事务回滚
}

PDO预处理语句

try{
//预处理SQL并绑定参数
$stmt = $conn -> prepare(“INSERT INTO test(name,age,sex) VALUES(:name,:age,:sex)”);
s t m t − &gt; b i n d P a r a m ( ′ : n a m e ′ , stmt-&gt;bindParam(&#x27;:name&#x27;, stmt>bindParam(:name,name);
s t m t − &gt; b i n d P a r a m ( ′ : a g e ′ , stmt-&gt;bindParam(&#x27;:age&#x27;, stmt>bindParam(:age,age);
s t m t − &gt; b i n d P a r a m ( ′ : s e x ′ , stmt-&gt;bindParam(&#x27;:sex&#x27;, stmt>bindParam(:sex,sex);
$name = “aimco”;
$age = “21”;
$sex = “1”;
//插入第一条数据
$stmt->execute();

//可以继续插入

echo "成功";

} catch(PDOException $e) {
echo $e -> getMessage();
}

预处理好处:
1.绑定参数减轻服务器的负担,只需要传输需要的参数即可,而不是整条sql语句
2.防止sql注入
如假如直接拼接:select * from test where uid = 1;select * from test2; //红色部分为参数,结果会执行select * from test2
预处理后:select * from test where uid = ‘1;select * from test2’; //整体为一个参数
预处理时会对参数进行转义,这个过程是透明的。
如转义成:select * from test where password = ‘ddd’ or ‘1’ = ‘1’;
3.提高执行效率:idk why

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值