0

0

简单的php写入数据库类代码分享

高洛峰

高洛峰

发布时间:2016-11-30 11:31:32

|

2203人浏览过

|

来源于php中文网

原创

有三个类: 
1 . 过滤输入(轻量级的) 
class input_filter 
负责将参数,如$_get,$_post 这些过滤 
返回值类型为 数组,用作 made_sql 类的参数 
2 . 转换成sql语句 
class made_sql 
参数的类型为数组和表名(字符串),数组的键名为表的列名,值为插入值 
返回值类型为 字符串 ,用作 mysql ->query方法 的参数 
3 . 数据库查询 
class mysql 
用到了单列模式,用静态方法来获取对象,具体参看 instanceof操作符的作用 
复制代码 代码如下: 
class input_filter 

private $input_all; // 要过滤的数组 
private $rustle; // 过滤后的结果 
//构造函数 参数可以是$_get or $_post 这些 
public function __construct($input_c) 

if(is_array($input_c)) 
$this->input_all = $input_c ; 
else 
echo 'parameter is not valid'; 
//初始化,不然后面第一次合并数组php不知道这是什么类型 
$this->rustle = array(); 

private function filter_arr() // 主函数 

foreach ($this->input_all as $key_input => $val_input) 

//如果键名不是字符串,那么返回错误信息 
// for key 
if(!is_string($key_input)) // error 

echo 'this key is not string'; 
return false; 

// the # is mysql note . 
$key_one = str_replace('#','',$key_input); 
$key = htmlspecialchars($key_one,ent_quotes,'utf-8'); 
// 我没找 # 的html转义符,所以用空代替 
$val_one = str_replace('#','',$val_input); 
// 这个函数只转化 ' " ,还有个类似函数会转义所有符号 
$val = htmlspecialchars($val_one,ent_quotes,'utf-8'); 
// merger 
$rustle_one = array($key=>$val); 
//合并数组 
$this->rustle = array_merge($this->rustle,$rustle_one); 


//这个函数有点多余,留下以后扩展用 
public function get_filter_rustle() 

$this->filter_arr(); 
return $this->rustle ; 



调用方法: 
复制代码 代码如下: 
$filter = new filter_input($_get) ; // or $_post 
$input_data = $filter->get_filter(); 

转换成sql语句: 
复制代码 代码如下: 
class madesql 

private $cnow_ary; // type array 传入的参数 
private $cname_str; 
private $insert_sql; //最终的sql语句 string type 
public function __construct($cary,$cname) 

//检查传入参数类型是否为数组 
if (! is_array($cary)) 
return false; 
else 
$this->cnow_ary = $cary; // 写入的值 
$this->cname_str = $cname; // 数据库表名称 
25 } 
private function setsql() // 主函数 ,生产sql语句 

foreach ( $this->cnow_ary as $key_ary => $val_ary ) 

$cols_sql = $cols_sql.','.$key_ary; //列名组合 
$vals_sql = $vals_sql.', \''.$val_ary.'\'' ; //值 组合 

// 因为前面foreach的算法有点问题,第一个字符是逗号 
// 所以用sunstr_replace()删除 ,自第一位起(0),只替换一个字符(1) 
$cols_sql = substr_replace($vals_sql,'',0,1); 
$vals_sql = substr_replace($vals_sql,'',0,1); 
$this->insert_sql = 
'insert into '.$this->cname_str.' ( ' 
.$cols_sql.' ) values ( '.$vals_sql.' )'; // 语句成型 

//扩展用 
public function getsql() 

$this->setsql(); 
return $this->insert_sql; 



3 . 数据库查询 
数据库查询类是参照书上的单列模式(用静态方法获取对象,这样在一个脚本里只有一个数据库查询类的实例) 
我想单例模式用于这个类还是有点用的 
复制代码 代码如下: 
class mysql 

private $connect; 
static $objectmysql; // 存放对象 
private function __construct() 7 { 
// 创建对象的时候这个构造函数会被调用,用来初始化 
$connect = mysql_connect('db address','password','dbname'); 
$this->db = mysql_select_db('db',$connect); 

public static function mysql_object() 

//instanceof 操作符用于检查对象是否属于某个类或者接口的实例。我说的不是很规范... 
//如果$objectmysql不是mysql(self)的实例,那么就创建一个 
if(! self::$objectmysql instanceof self) 
self::$objectmysql = new mysql(); 
//这时候的$objectmysql就已经是一个对象 
return self::$objectmysql; 

public function query($sql) 

return mysql_query($sql,$this->db); 


   

all right ,归纳一下使用方法 
复制代码 代码如下: 
$filter = new filter_input($_get) ; // or $_post 
$input_data = $filter->get_filter(); 
$madesql = new madesql($input_data,'tablename'); 
$sql = $madesql->getsql(); 
$mysql = mysql::mysql_object() ; 
if( $mysql->query($sql) ) 
echo 'ok'; 
else 
echo 'failure'; 

只需要这几行调用代码即可以完成写入数据库的操作 
另外再说一下构造函数的私有公有问题,书上的mysql单例模式中构造函数是声明为了private ,而没有单例模式的类如此则会产生编译错误,即 php 不能创建一个对象 ,查了下。 

原因在于创建对象往往在类外面进行,这样就产生了无法访问构造函数的问题。 而单列模式是在自身类中创建对象,因此访问private方法没有限制。 

原先以为单例模式只是防止创建相同的对象,现在看来单例模式可以将构造函数封装起来,确实提高了安全性 
  filter_input类 的结果可以直接用作 madesql类 的参数的 前提是 : 
表单的name必须和数据库的列名相同,否则你就白看这么多

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

php

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

391

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

135

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

233

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

8

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

13

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

10

2026.01.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

24

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

124

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

98

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号