pdo mysql_PDO MySQL

PDO MySQL

如果文章有成千上万篇,该怎样保存?

数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做Web一般采用MySQL,本书也以MySQL为例。

自学:1天。

假设这个在线阅读项目叫做“reader”,需要一个“文章”表“articles”。建库建表代码如下:

CREATE DATABASE `reader` DEFAULT CHARACTER SET utf8;

USE `reader`;

CREATE TABLE `articles` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`author` varchar(20) DEFAULT NULL,

`title` varchar(50) DEFAULT NULL,

`content` text NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

然后修改add_article_submit.php,把文章保存到数据库中即可。代码如下:

$input = $_POST;

$dsn = 'mysql:host=127.0.0.1;port=3306;dbname=reader;charset=utf8';

$user = 'root';

$password = '1';

$db = new PDO($dsn, $user, $password); //连接数据库

$sql = 'INSERT INTO `articles` (`author`, `title`, `content`) VALUES (' . '\'' . $input['author'] . '\',\'' . $input['title'] . '\',\'' . $input['content'] . '\');';

$stmt = $db->query($sql); //执行SQL

$id = $db->lastInsertId(); //获得自增id

if (!empty($id)) {

$notice = '保存成功';

} else {

$notice = '出错了';

}

$d = array();

$d['notice'] = array(

'msg' => '保存成功',

);

require_once __DIR__ . '/notice.html';

然后首页index.php把这些文章查出来即可,代码如下:

$dsn = 'mysql:host=127.0.0.1;port=3306;dbname=reader;charset=utf8';

$user = 'root';

$password = '1';

$db = new PDO($dsn, $user, $password);

$sql = 'SELECT `id`, `author`, `title`, `content` FROM `articles` LIMIT 10';

$stmt = $db->query($sql);

$stmt->setFetchMode(PDO::FETCH_ASSOC);

$articles = $stmt->fetchAll();

$d = array();

$d['articles'] = $articles;

require_once __DIR__ . '/index.html';

然后单篇阅读页get_article.php,根据id,查出一篇即可,这样比查出来所有文章合理多了。代码如下:

$input = $_GET;

$d = array();

if (!isset($input['id']) || empty($input['id'])) {

$d['notice'] = array(

'msg' => '出错了:缺少参数',

);

require __DIR__ . '/notice.html';

exit;

}

$dsn = 'mysql:host=127.0.0.1;port=3306;dbname=reader;charset=utf8';

$user = 'root';

$password = '1';

$db = new PDO($dsn, $user, $password);

$sql = 'SELECT `author`, `title`, `content` FROM `articles` WHERE id=' . $input['id'] . ' LIMIT 1';

$stmt = $db->query($sql);

$stmt->setFetchMode(PDO::FETCH_ASSOC);

$r = $stmt->fetchAll();

if (empty($r)) {

$d['notice'] = array(

'msg' => '出错了:查无此文',

);

require __DIR__ . '/notice.html';

exit;

}

$d = array();

$d['article'] = $r[0];

require_once __DIR__ . '/get_article.html';

现在可以发表、查看首页、单篇阅读,功能都实现了。

总结一下

我的技术水平

HTMLPHP数据存储HTTP协议程序员的自我修养装备等级
语义化让内容动起来单机文件GET、POSTPC + Windows0.2
表现与业务分离charsetUnicode0.3
PDOMySQL0.4

已解决的问题

如何用PHP操作MySQL数据库?

使用PDO即可。

PDO、php_mysqli和php_mysql的区别是什么?

请自学了解。注意:php_mysql已废弃。

没钱,对现在的年轻人意味着什么?

luckystar神探:来,讲个故事。 从前有个骚年叫小明。不是姚小明,不是黄小明,也不是郭小明。就是一个普普通通的、扎人堆里找不出来的小明。 男,二十多岁,家境普通。口头禅是「还不是因为老子穷」。 高中时,和… http://zhi.hu/1P8D(分享自知乎)

待解决的问题

index.php、get_article.php等多个文件里都连了数据库,如果密码变了,每个地方都要改,怎么办?

且听下回分解。

访问index.php是正常网页,但访问index.html看到了什么?

请进行实验。且听下回分解。

单引号能保存吗?会导致什么后果?

请按照截图进行实验。且听下回分解。

single_quote_mark.png

单引号实验保存1

sql_injection.png

单引号实验保存2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307005.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 8: 可变结构体中的只读实例成员

在之前的文章中我们介绍了 C# 中的 只读结构体(readonly struct)[1] 和与其紧密相关的 in 参数[2]。今天我们来讨论一下从 C# 8 开始引入的一个特性:可变结构体中的只读实例成员(当结构体可变时,将不会改变结构体状态的…

部署Dotnet Core应用到Kubernetes(一)

最近闲了点,写个大活:部署Dotnet应用到K8s。写在前边的话一直想完成这个主题。但这个主题实在太大了,各种拖延症的小宇宙不时爆发一下,结果就拖到了现在。这个主题,会是一个系列。在这个系列中,我会讨论将应…

JAVA实验报告九异常处理_Java课后练习9(异常处理)

动手动脑1:import javax.swing.*;class AboutException {public static void main(String[] a){int i1, j0, k;ki/j;try{k i/j; // Causes division-by-zero exception//throw new Exception("Hello.Exception!");}catch ( ArithmeticException e){System.out.print…

java 实现 指派_TAP任务指派问题的汇编实现

近六周的课程设计,编了一个四百行的汇编程序,编的过程很不顺利,遇到种种意想不到的困难,但最终能够实现,可谓欣喜若狂,这期间学到了好多好多,遇到问题怎么精下心来解决,同时对汇编的…

.NET 5.0正式发布,有什么功能特性(翻译)

我们很高兴今天.NET5.0正式发布。这是一个重要的版本—其中也包括了C# 9和F# 5大量新特性和优秀的改进。微软和其他公司的团队已经在生产和性能测试环境中开始使用了。这些团队向我们反馈的结果比较令人满意,它证明了对性能提升及降低Web应用托管成本的机会有积极的…

简单聊聊C#中lock关键字

为了避免多个线程同时操作同一资源,引起数据错误,通常我们会将这个资源加上锁,这样在同一时间只能有一个线程操作资源。在C#中我们使用lock关键字来锁定资源,那lock关键字是如何实现锁定的呢?我们先看一段代码&#xf…

idea如何导入java工程_Eclipse java web项目 ,导入IntelliJ IDEA 完整操作!

或许你用惯了Eclipse,有点排斥其他工具了,你写框架的时候,编译速度是不是特别慢啊?有时候还超过45秒,自动取消运行!有时候代码是正常的,却无端端报错?下午吃个饭回来又好了&#xff…

行业思考 | 互联网对传统行业的降维打击

【行业思考】| 作者 / Edison Zhou这是EdisonTalk的第301篇原创内容在周一发布的推文《我在传统行业做数字化转型之预告篇》中,我提到互联网的发展和和竞争对传统行业起到了降维打击的作用,于是就有童鞋私下问我,为何这么说。今天就跟你聊聊这…

BCVP开发者说第一期:Destiny.Core.Flow

沉静岁月,淡忘流年1项目简介Destiny.Core.FlowDestiny.Core.Flow是基于.NetCore平台,轻量级的模块化开发框架,Admin管理应用框架,旨在提升团队的快速开发输出能力,由常用公共操作类(工具类、帮助类&#xf…

.NET Core 取消令牌:CancellationToken

在 .NET 开发中,CancellationToken(取消令牌)是一项比较重要的功能,掌握并合理的使用 CancellationToken 可以提升服务的性能。特别在异步编程中,我常常会以创建 Task 的方式利用多线程执行一些耗时或非核心业务逻辑&a…

java char short区别_java 彻底理解 byte char short int float long double

遇到过很多关于 数值类型范围的问题了,在这做一个总结,我们可以从多方面理解不同数值类型的所能表示的数值范围在这里我们只谈论 java中的数值类型首先说byte:这段是摘自jdk中 Byte.java中的源代码从这里可以看出 byte的取值范围:…

程序员过关斩将--从未停止过的系统架构设计步伐

“首先,这篇文章肯定会得罪一些人“其次,此文只代表我个人的意见,仅供参考从分层说起谈到系统架构的分层和系统领域边界的划分,每个架构师,每个技术经理,甚至每个程序员都有自己的一套想法。无论是怎么样的…

BCVP第2期:项目已完成升级.NET5.0

(是时候拿出来这种图了)1开心的锣鼓想必这两天最热闹的几个词语,就是c#9.0、.net5.0还有conf大会了吧,当然还有大一统。其实,早在2019年年中,就已经引入了.NET5.0了,然后从2020-03-16开始,就一直在说.NET5.…

如何在ASP.NetCore增加文件上传大小

关注架构师高级俱乐部开启架构之路不定期福利发放哦~架构师高级俱乐部读完需要7分钟速读仅需 3 分钟/ 如何在核心中增加文件 ASP.NET 大小 /从ASP.NET 2.0开始最大请求正文大小限制为30MB (28.6 MiB)。在正常情况下,无需增加 HTTP 请求 body …

java完全二叉树最小堆_Java实现最小堆一

Java实现最小堆一堆是一种经过排序的完全二叉树,其中任一非终端节点的数据值均不大于(或不小于)其左孩子和右孩子节点的值。最大堆和最小堆是二叉堆的两种形式。最大堆:根结点的键值是所有堆结点键值中最大者。最小堆:根结点的键值是所有堆结…

一个 Task 不够,又来一个 ValueTask ,真的学懵了!

一:背景 1. 讲故事前几天在项目中用 MemoryStream 的时候意外发现 ReadAsync 方法多了一个返回 ValueTask 的重载,真是日了狗了,一个 Task 已经够学了,又来一个 ValueTask,晕,方法签名如下:publ…

Magicodes.IE 3.0重磅设计畅谈

Magicodes.IE 3.0重磅设计畅谈总体设计图Magicodes.IE导入导出通用库,支持Dto导入导出、模板导出、花式导出以及动态导出,支持Excel、Csv、Word、Pdf和Html。IE在去年年底重构一次之后,经过这么长时间的迭代,又迎来了瓶颈。根据本…

php引用类,thinkphp引用类的使用

比如发送邮件类phpmailer1.将核心文件放入ORG目录下2.在使用的地方,引入这个类文件如何引入呢?import(.ORG.phpmailer);这个表示引入当前项目中的ORG中的phpmailer.class.php文件3.引入之后就可以使用文件中的类了public function sendEmail() {import(.…

Net5 已经来临,让我来送你一个成功

没错,那就是“下载成功”。现在,已经可以急速下载.Net5 docker 镜像 .Net 5 进行今天已经正式发布,想必各位已经通过各种渠道了解到了此次发布的所有内容。并且也都体会到了这次凑成三连的金 scott 是什么效果(啊哈,三…

推荐几款强大流行的BI系统

高级架构师俱乐部 读完需要2分钟速读仅需 1 分钟企业在日常运营过程中,需要根据公司实时经营数据来做未来决测或者发现经营中的问题,在此过程中离不开对数据的分析,而平常利用 excel 等方式极大的提高了领导层快速做出决测的成本&#xff0c…