亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

簡單的php寫入數據庫類代碼分享

2024-05-04 23:17:40
字體:
來源:轉載
供稿:網友
不知道原創要寫到隨筆里。
All right ,第一篇博文。
有三個類:
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必須和數據庫的列名相同,否則你就白看這么多
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲国产成人精品| 九九热99久久久国产盗摄| 国产美女久久久| 性色av一区二区三区红粉影视| 国产中文字幕91| 精品久久久久久久久国产字幕| 日韩成人xxxx| 亚洲视频在线免费看| 亚洲自拍偷拍第一页| 国产精品ⅴa在线观看h| 456国产精品| 久久精品成人欧美大片| 久久精品国产91精品亚洲| 久久777国产线看观看精品| 国产在线精品一区免费香蕉| 日韩一区二区av| 日韩av中文字幕在线播放| 福利视频第一区| 久久久在线免费观看| 正在播放欧美一区| 国产suv精品一区二区| 日韩乱码在线视频| 亚洲视频一区二区| 国产精品视频公开费视频| 国产91在线播放精品91| 欧美一级大片视频| 国产精品视频久久久久| 97精品视频在线播放| 欧美精品激情视频| 中文字幕精品国产| 成人黄色片网站| 中文字幕不卡在线视频极品| 国产欧美韩国高清| 精品女厕一区二区三区| 亚洲高清久久久久久| 午夜精品www| 97视频在线观看免费高清完整版在线观看| 亚洲欧美日韩区| 亚洲男女性事视频| 日韩亚洲欧美中文高清在线| 亚洲视频在线播放| 韩国日本不卡在线| 亚洲最大中文字幕| 亚洲新声在线观看| 伊人精品在线观看| 国产精品美女呻吟| 69av视频在线播放| 九九热这里只有在线精品视| 在线播放国产一区中文字幕剧情欧美| 欧美最近摘花xxxx摘花| 久久免费少妇高潮久久精品99| 欧美黑人一级爽快片淫片高清| 久久天天躁夜夜躁狠狠躁2022| 国产精品久久国产精品99gif| 国产成人亚洲综合91精品| 欧美大奶子在线| 伊人久久久久久久久久久久久| 国产午夜精品免费一区二区三区| 久久久女女女女999久久| 久久综合国产精品台湾中文娱乐网| 国产精彩精品视频| 久久天天躁狠狠躁夜夜爽蜜月| 国产一区视频在线播放| 中文字幕欧美在线| 国产亚洲精品久久久久动| 一区二区三区 在线观看视| 欧美另类69精品久久久久9999| 国产精品高清网站| 亚洲综合色激情五月| 色综合视频一区中文字幕| 亚洲精品国产欧美| 91日本视频在线| 亚洲最大av网站| 欧美成人全部免费| 久久香蕉频线观| 欧洲亚洲免费视频| 正在播放欧美一区| 欧美成人激情视频免费观看| 91超碰中文字幕久久精品| 日韩高清电影免费观看完整| 成人中心免费视频| 久久久久久久999精品视频| 日本高清久久天堂| 日本a级片电影一区二区| 亚洲国产精品高清久久久| 九九热精品视频在线播放| 欧美成在线视频| 欧美成人久久久| 狠狠色狠狠色综合日日小说| 国产一区二区三区欧美| 日韩国产中文字幕| 成人午夜一级二级三级| 日韩视频免费在线观看| 日韩麻豆第一页| 成人黄色免费网站在线观看| 另类少妇人与禽zozz0性伦| 久久久久久久久久国产| 久久99久久99精品中文字幕| 色妞在线综合亚洲欧美| 国产欧美日韩专区发布| 91色琪琪电影亚洲精品久久| 日韩av日韩在线观看| 亚洲男人第一网站| 国产91露脸中文字幕在线| 国产精品成人播放| 久久精品99无色码中文字幕| 欧美日韩国产黄| 性欧美xxxx视频在线观看| 久久在线视频在线| 热久久免费视频精品| 欧美精品成人91久久久久久久| 在线观看91久久久久久| 亚洲欧洲在线视频| 国产精品久久久久77777| 国产高清视频一区三区| 97视频在线观看免费高清完整版在线观看| 在线观看免费高清视频97| 亚洲综合小说区| 国产精品精品视频一区二区三区| 日韩国产在线播放| 在线观看欧美日韩国产| 欧美超级乱淫片喷水| 国产精品日韩欧美综合| 欧美中文在线免费| 亚洲国产精品久久久久久| 亚洲欧美制服综合另类| 国产aaa精品| 美女啪啪无遮挡免费久久网站| 亚洲女人天堂视频| 这里只有精品丝袜| 国语自产精品视频在线看| 超碰97人人做人人爱少妇| 欧美在线一级视频| 国产亚洲精品va在线观看| 国产精品成久久久久三级| 欧美精品激情视频| 国产精品永久免费| 国产日韩精品电影| 91久久久久久久久久久久久| 欧美精品激情视频| 国产精品久久久久久久7电影| 欧美视频免费在线观看| 久久久久国色av免费观看性色| 国产精品视频播放| 97视频在线观看成人| 国产精品情侣自拍| 欧美高清视频免费观看| 91av视频在线观看| 亚洲日本中文字幕免费在线不卡| 91免费人成网站在线观看18| 国产精品电影久久久久电影网| 另类少妇人与禽zozz0性伦| 97婷婷涩涩精品一区| 亚洲国产精品va在线看黑人| 国产精品视频成人| 91免费精品国偷自产在线| 国产91精品最新在线播放| 欧美久久精品一级黑人c片| 久久久免费精品视频| 国产亚洲精品久久久优势| 欧美电影院免费观看| 日韩最新av在线| 亚洲一区二区三区四区视频| 国产成人短视频|