首頁 後端開發 php教程 php操作mysql的類

php操作mysql的類

Jul 25, 2016 am 08:42 AM

exit(); }

[PHP]代碼

  1. class mysql {
  2. private $db_host; //資料庫主機
  3. private $db_user; //資料庫使用者名稱
  4. private $private $ ; //資料庫使用者名稱密碼
  5. private $db_database; //資料庫名稱
  6. private $conn; //資料庫連線識別;
  7. private $result; //執行query指令的結果資源識別碼
  8. private $sql; //sql執行語句
  9. private $row; //傳回的條目數
  10. private $coding; //資料庫編碼,GBK,UTF8,gb2312
  11. private $bulletin = true; //是否開啟錯誤記錄
  12. private $show_error = false; //測試階段,顯示所有錯誤,具有安全隱患,預設關閉
  13. private $is_error = false; //發現錯誤是否立即終止,預設true,建議不啟用,因為當有問題時使用者什麼也看不到是很苦惱的
  14. /*建構子*/
  15. public function __construct($db_host, $db_user, $db_pwd, $db_database, $conn , $coding) {
  16. $this->db_host = $db_host;
  17. $this->db_user = $db_user;
  18. $this->db_pwd = $db_pwd;
  19. $this->db_database = = $db_database;
  20. $this->conn = $conn;
  21. $this->coding = $coding;
  22. $this->connect();
  23. }
  24. /*資料庫連線*/
  25. public function connect() {
  26. if ($this->conn == "pconn") {
  27. //永久連結
  28. $this->conn = mysql_pconnect($this ->db_host, $this->db_user, $this->db_pwd);
  29. } else {
  30. //即使連結
  31. $this->conn = mysql_connect($this->db_host, $this- >db_user, $this->db_pwd);
  32. }
  33. if (!mysql_select_db($this->db_database, $this->conn)) {
  34. if ($this->show_error) {
  35. $this->show_error("資料庫不可用:", $this->db_database);
  36. }
  37. }
  38. mysql_query("SET NAMES $this->coding");
  39. }
  40. /*資料庫執行語句,可執行查詢新增修改刪除等任何sql語句*/
  41. public function query($sql) {
  42. if ($sql == "") {
  43. $this->show_error("SQL語句錯誤:", "SQL查詢語句為空");
  44. }
  45. $this->sql = $sql;
  46. $result = mysql_query($this->sql, $this->conn);
  47. if (!$result) {
  48. //調試中使用,sql語句出錯時會自動列印出來
  49. if ( $this->show_error) {
  50. $this->show_error("錯誤SQL語句:", $this->sql);
  51. }
  52. } else {
  53. $this->result = $ result;
  54. }
  55. return $this->result;
  56. }
  57. /*建立新增新的資料庫*/
  58. public function create_database($database_name) {
  59. $
  60. $ database = $database_name;
  61. $sqlDatabase = 'create database ' . $database;
  62. $this->query($sqlDatabase);
  63. }
  64. /*查詢伺服器所有資料庫*/ //將系統資料庫與使用者資料庫分開,更直覺的顯示?
  65. public function show_databases() {
  66. $this->query("show databases");
  67. echo "現有資料庫:" . $amount = $this->db_num_rows($rs);
  68. echo "
    ";
  69. $i = 1;
  70. while ($row = $this->fetch_array($rs)) {
  71. echo "$i $row[Database]";
  72. echo "
    ";
  73. $i ;
  74. }
  75. }
  76. //以陣列形式傳回主機中所有資料庫名稱
  77. public function databases() {
  78. $rsPtr = mysql_list_dbs($this->conn);
  79. $i = 0;
  80. $cnt = mysql_num_rows($rsPtr);
  81. while ($i $rs[] = mysql_db_name($rsPtr, $i);
  82. $i ;
  83. }
  84. return $rs;
  85. }
  86. /*查詢資料庫下所有的表*/
  87. public function show_tables($database_name) {
  88. $this->query("show tables");
  89. echo "現有資料庫:" . $amount = $this->db_num_rows($rs );
  90. echo "
    ";
  91. $i = 1;
  92. while ($row = $this->fetch_array($rs)) {
  93. $columnName = "Tables_in_" . $database_name;
  94. echo "$i $row[$columnName]";
  95. echo "
    ";
  96. $i ;
  97. }
  98. }
  99. / *
  100. mysql_fetch_row() array $row[0],$row[1],$row[2]
  101. mysql_fetch_array() array $row[0] 或$row[id]
  102. mysql_fetch_assoc() array用$row->content 欄位大小寫敏感
  103. mysql_fetch_object() object 用$row[id],$row[content] 欄位大小寫敏感
  104. */
  105. /*取得結果資料* /
  106. public function mysql_result_li() {
  107. return mysql_result($str);
  108. }
  109. /*取得記錄集,取得陣列-索引和關聯,使用$row['content' ] */
  110. public function fetch_array($resultt="") {
  111. if($resultt""){
  112. return mysql_fetch_array($resultt);
  113. }else{
  114. return mysql_fetch_array($this->result);
  115. }
  116. }
  117. //取得關聯陣列,使用$row['欄位名稱']
  118. public function fetch_assoc() {
  119. return mysql_fetch_assoc($this->result);
  120. }
  121. //取得數字索引陣列,使用$row[0],$row[1],$row[2]
  122. public function fetch_row() {
  123. return mysql_fetch_row($this->result);
  124. }
  125. //取得物件陣列,使用$row->content
  126. public function fetch_Object() {
  127. return mysql_fetch_object($this->result);
  128. }
  129. //簡化查詢select
  130. public function findall($table) {
  131. $this->query("SELECT * FROM $table");
  132. }
  133. //簡化查詢select
  134. public function select($table, $columnName = "*", $condition = '', $debug = '') {
  135. $condition = $condition ? ' Where ' . $condition : NULL;
  136. if ($debug) {
  137. echo "SELECT $columnName FROM $table $condition";
  138. } else {
  139. $this->query("SELECT $columnName FROM $table $condition");
  140. }
  141. }
  142. //簡化刪除del
  143. public function delete($table, $condition , $url = '') {
  144. if ($this->query("DELETE FROM $table WHERE $condition")) {
  145. if (!empty ($url))
  146. $this-> Get_admin_msg($url, '刪除成功! ');
  147. }
  148. }
  149. //簡化插入insert
  150. public function insert($table, $columnName, $value, $url = '') {
  151. if ( $this->query("INSERT INTO $table ($columnName) VALUES ($value)")) {
  152. if (!empty ($url))
  153. $this->Get_admin_msg($url, '加成功!');
  154. }
  155. }
  156. //简化修改update
  157. public function update($table, $mod_content, $condition, $url = '') {
  158. //echo "UPDATE $table SET $mod_content WHERE $condition"; exit();
  159. if ($this->query("UPDATE $table SET $mod_content WHERE $condition")) {
  160. if (!empty ($url))
  161. $this->Get_admin_msg($url);
  162. }
  163. }
  164. /*取得上一步 INSERT 操作产生的 ID*/
  165. public function insert_id() {
  166. return mysql_insert_id();
  167. }
  168. //指向确定的一条数据记录
  169. public function db_data_seek($id) {
  170. if ($id > 0) {
  171. $id = $id -1;
  172. }
  173. if (!@ mysql_data_seek($this->result, $id)) {
  174. $this->show_error("SQL语句有误:", "指定的数据为空");
  175. }
  176. return $this->result;
  177. }
  178. // 根据select查询结果计算结果集条数
  179. public function db_num_rows() {
  180. if ($this->result == null) {
  181. if ($this->show_error) {
  182. $this->show_error("SQL语句错误", "暂时为空,没有任何内容!");
  183. }
  184. } else {
  185. return mysql_num_rows($this->result);
  186. }
  187. }
  188. // 根据insert,update,delete执行结果取得影响行数
  189. public function db_affected_rows() {
  190. return mysql_affected_rows();
  191. }
  192. //输出显示sql语句
  193. public function show_error($message = "", $sql = "") {
  194. if (!$sql) {
  195. echo "" . $message . "";
  196. echo "
    ";
  197. } else {
  198. echo "
    ";
  199. echo "错误信息提示:
    ";
  200. echo "
    ";
  201. echo "
    ";
  202. echo "错误号:12142";
  203. echo "

";
  • echo "错误原因:" . mysql_error() . "

    ";
  • echo "
    ";
  • echo "" . $message . "";
  • echo "
  • ";
  • echo "
    " . $sql . "
    ";
  • $ip = $this->getip();
  • if ($this->bulletin) {
  • $time = date("Y-m-d H:i:s");
  • $message = $message . "\r\n$this->sql" . "\r\n客户IP:$ip" . "\r\n时间 :$time" . "\r\n\r\n";
  • $server_date = date("Y-m-d");
  • $filename = $server_date . ".txt";
  • $file_path = "error/" . $filename;
  • $error_content = $message;
  • //$error_content="错误的数据库,不可以链接";
  • $file = "error"; //设置文件保存目录
  • //建立文件夹
  • if (!file_exists($file)) {
  • if (!mkdir($file, 0777)) {
  • //默认的 mode 是 0777,意味着最大可能的访问权
  • die("upload files directory does not exist and creation failed");
  • }
  • }
  • //建立txt日期文件
  • if (!file_exists($file_path)) {
  • //echo "建立日期文件";
  • fopen($file_path, "w+");
  • //首先要确定文件存在并且可写
  • if (is_writable($file_path)) {
  • //使用添加模式打开$filename,文件指针将会在文件的开头
  • if (!$handle = fopen($file_path, 'a')) {
  • echo "不能打开文件 $filename";
  • exit;
  • }
  • //将$somecontent写入到我们打开的文件中。
  • if (!fwrite($handle, $error_content)) {
  • echo "不能写入到文件 $filename";
  • exit;
  • }
  • //echo "文件 $filename 写入成功";
  • echo "——错误记录被保存!";
  • //关闭文件
  • fclose($handle);
  • } else {
  • echo "文件 $filename 不可写";
  • }
  • } else {
  • //首先要确定文件存在并且可写
  • if (is_writable($file_path)) {
  • //使用添加模式打开$filename,文件指针将会在文件的开头
  • if (!$handle = fopen($file_path, 'a')) {
  • echo "不能打开文件 $filename";
  • exit;
  • }
  • //将$somecontent写入到我们打开的文件中。
  • if (!fwrite($handle, $error_content)) {
  • echo "不能写入到文件 $filename";
  • exit;
  • }
  • //echo "文件 $filename 写入成功";
  • echo "——错误记录被保存!";
  • //关闭文件
  • fclose($handle);
  • } else {
  • echo "文件 $filename 不可写";
  • }
  • }
  • }
  • echo "
    ";
  • if ($this->is_error) {
  • exit;
  • }
  • }
  • echo "";
  • echo "";
  • echo "
    ";
  • }
  • //釋放結果集
  • public function free( ) {
  • @ mysql_free_result($this->result);
  • }
  • //資料庫選擇
  • public function select_db($db_database) {
  • return mysql_select_db($
  • }
  • //查詢欄位數
  • public function num_fields($table_name) {
  • //return mysql_num_fields($this->result);
  • $this->quesql_num_fields($this->result);
  • $this->quesql( "select * from $table_name");
  • echo "
    ";
  • echo "字段數:" . $total = mysql_num_fields($this->result);
  • echo "
     ";
    登入後複製
  • for ($i = 0; $i print_r(mysql_fetch_field($this->result, $i));
  • }
  • echo "";
  • echo "
    ";
  • }
  • //取得MySQL 伺服器資訊
  • public function mysql_server($num = '') {
  • switch ($num) {
  • case 1 :
  • return mysql_get_server_info(); //MySQL 伺服器資訊
  • break;
  • case 2 :
  • return mysql_getget_info(); //取得主機資訊
  • break;
  • case 3 :
  • return mysql_get_client_info(); //取得MySQL 用戶端資訊
  • break;
  • case 客戶端資訊
  • break;
  • break;
  • break;
  • break;
  • break;
  • break;
  • break;
  • 。 (); //取得MySQL 協議信息
  • break;
  • default :
  • return mysql_get_client_info(); //默認取得mysql版本信息
  • }
  • }
  • //析構函數,自動關閉資料庫,垃圾回收機制
  • public function __destruct() {
  • if (!empty ($this->result)) {
  • $this->free();
  • }
  • mysql_close($this->conn);
  • } //function __destruct();
  • /*取得客戶端真實的IP位址*/
  • function getip( ) {
  • if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")) {
  • $ip = getenv("HTTP_CLIENT_IP")) {
  • $ip = getenv("HTTP_CLIENT_IP"); if (getenv("HTTP_X_FORWARDED_FOR") &&strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown")) {
  • $ip = getenv("HTTP_X_FORWARDED_getOR"); $ip = getenv("REMOTE_ADDR");
  • } else
  • if (isset ($_SERVER['REMOTE_ADDR'] ) && $_SERVER['REMOTE_ADDR'] &&strcasecmp($_SERVER['REMOTE_ADDR'], "unknown")) {
  • $ip = $_SERVER['REMOTE_ADDR'];
  • } else {
  • $ipipip = "unknown";
  • }
  • return ($ip);
  • }
  • function inject_check($sql_str) { //防止注入
  • $check =eregi('select|insert|update |delete|'|/*|*|../|./|union|into|load_file|outfile',$sql_str);
  • if ($check) {
  • echo "輸入非法注入內容! ";
  • exit ();
  • } else {
  • return $sql_str;
  • } } function checkurl() { //檢查來路 if (preg_replace( "/https?://([^:/] ).*/i", "\1", $_SERVER['HTTP_REFERER']) !== preg_replace("/([^:] ).*/" , "\1", $_SERVER['HTTP_HOST'])) { header("Location: http://www.dareng.com");
    }
    }?>
    複製程式碼


    php, mysql
    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    AI Hentai Generator

    AI Hentai Generator

    免費產生 AI 無盡。

    熱門文章

    R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
    1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.最佳圖形設置
    1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
    威爾R.E.P.O.有交叉遊戲嗎?
    1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

    JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

    描述紮實的原則及其如何應用於PHP的開發。 描述紮實的原則及其如何應用於PHP的開發。 Apr 03, 2025 am 12:04 AM

    SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

    如何在系統重啟後自動設置unixsocket的權限? 如何在系統重啟後自動設置unixsocket的權限? Mar 31, 2025 pm 11:54 PM

    如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

    解釋PHP中晚期靜態結合的概念。 解釋PHP中晚期靜態結合的概念。 Mar 21, 2025 pm 01:33 PM

    文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

    如何用PHP的cURL庫發送包含JSON數據的POST請求? 如何用PHP的cURL庫發送包含JSON數據的POST請求? Apr 01, 2025 pm 03:12 PM

    使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...

    框架安全功能:防止漏洞。 框架安全功能:防止漏洞。 Mar 28, 2025 pm 05:11 PM

    文章討論了框架中的基本安全功能,以防止漏洞,包括輸入驗證,身份驗證和常規更新。

    自定義/擴展框架:如何添加自定義功能。 自定義/擴展框架:如何添加自定義功能。 Mar 28, 2025 pm 05:12 PM

    本文討論了將自定義功能添加到框架上,專注於理解體系結構,識別擴展點以及集成和調試的最佳實踐。

    See all articles