php实现简单链式操作mysql数据库类
<?php
$dbConfig = require_once(dirname(__FILE__).'/config.php'); class Db{
public $conn;
private $host = null;
private $user = null;
private $password = null;
private $database = null;
private $tablename = null;
private $dbConfig = null;
private $sql = [
'where' => null,
'orderBy' => null,
'limit' => null,
]; public function __construct($tablename = '') {
global $dbConfig;
$this->dbConfig = $dbConfig;
$this->tablename = $dbConfig['DB_PREFIX'].$tablename;
$this->user = $dbConfig['DB_USER'];
$this->host = $dbConfig['DB_HOST'];
$this->password = $dbConfig['DB_PWD'];
$this->database = $dbConfig['DB_NAME'];
$dsn = 'mysql:dbname='.$this->database.';host='.$this->host.';port=3306';
try {
$this->conn = new PDO($dsn, $this->user, $this->password); // also allows an extra parameter of configuration
} catch(PDOException $e) {
die('Could not connect to the database:<br/>' . $e);
}
} public function table($tablename) {
$this->tablename = $this->dbConfig['DB_PREFIX'].$tablename;
return $this;
} public function getAll($fields = '*') {
$querySql = sprintf("SELECT %s FROM %s", $fields, $this->tablename);
if(!empty($this->sql['where'])) {
$querySql .= ' WHERE ' . $this->sql['where'];
}
if(!empty($this->sql['orderBy'])) {
$querySql .= ' ORDER BY ' . $this->sql['orderBy'];
}
if(!empty($this->sql['limit'])) {
$querySql .= ' LIMIT ' . $this->sql['limit'];
}
return $this->query($querySql);
} public function getOne($fields = '*') {
$result = $this->getAll($fields);
return isset($result[0]) ? $result[0] : null;
} public function insert($data) {
foreach ($data as $key => &$value) {
$value = addslashes($value);
}
$keys = "`".implode('`,`', array_keys($data))."`";
$values = "'".implode("','", array_values($data))."'";
$querySql = sprintf("INSERT INTO %s ( %s ) VALUES ( %s )", $this->tablename, $keys, $values);
return $this->query($querySql);
} public function delete() {
$querySql = sprintf("DELETE FROM %s WHERE ( %s )", $this->tablename, $this->sql['where']);
return $this->query($querySql);
} public function update($data) {
$updateFields = [];
foreach ($data as $key => $value) {
$up_value = addslashes($value);
$updateFields[] = "`$key`='$up_value'";
}
$updateFields = implode(',', $updateFields);
$querySql = sprintf("UPDATE %s SET %s", $this->tablename, $updateFields); if(!empty($this->sql['where'])) {
$querySql .= ' WHERE ' . $this->sql['where'];
} return $this->query($querySql);
} public function query($querySql) {
$querystr = strtolower(trim(substr($querySql,0,6)));
$stmt = $this->conn->prepare($querySql);
$ret = $stmt->execute(); if(!$ret) print_r($stmt->errorInfo()); if($querystr == 'select') {
$retData = $stmt->fetchAll(PDO::FETCH_ASSOC);
return $retData;
}elseif($ret && $querystr == 'insert') {
return $this->conn->lastInsertId();
}else{
return $ret;
}
} public function limit($limit, $limitCount = null) {
if(!$limitCount) {
$this->sql['limit'] = $limit;
}else{
$this->sql['limit'] = $limit .','. $limitCount;
}
return $this;
} public function orderBy($orderBy) {
$this->sql['orderBy'] = $orderBy;
return $this;
} public function close() {
return $this->conn = null;
} public function where($where) {
if(!is_array($where)) {
return null;
}
$crondsArr = [];
foreach ($where as $key => $value) {
$fieldValue = $value;
if(is_array($fieldValue)) {
$crondsArr[] = "$key ".$fieldValue[0]. ' ' . addslashes($fieldValue[1]);
}else{
$fieldValue = addslashes($fieldValue);
$crondsArr[] = "$key='$fieldValue'";
}
}
$this->sql['where'] = implode(' AND ', $crondsArr); return $this;
}
}
php实现简单链式操作mysql数据库类的更多相关文章
- Spring Data R2DBC响应式操作MySQL
1. 前言 在使用R2DBC操作MySQL数据库 一文中初步介绍了r2dbc-mysql的使用.由于借助DatabaseClient操作MySQL,过于初级和底层,不利于开发.今天就利用Spring ...
- Code First操作Mysql数据库
前面博客也讲了,自己做一个网站,选用的是MVC+EF Code First+MySql+EasyUI,先说下技术选型.一.为什么选择MVC? 因为之前自己做的系统大部分是webForm,MVC的之前也 ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- Java 操作MySql数据库
Java 项目开发中数据库操作是很重要的一个方面,对于初学者来说,MySql是比较容易熟悉的一种常见数据库,这篇文章记录了如何用Java来操作MySql数据库. 第一章 JDBC的概念 JDBC(Ja ...
- mysqli扩展库操作mysql数据库
配置环境 配置php.ini文件让php支持mysqli扩展库 extension=php_mysqli.dll 建库建表 详见博客 “mysql扩展库操作mysql数据库” 查询数据库 <?p ...
- python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy
内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...
- 本地通过Eclipse链接Hadoop操作Mysql数据库问题小结
前一段时间,在上一篇博文中描述了自己抽时间在构建的完全分布式Hadoop环境过程中遇到的一些问题以及构建成功后,通过Eclipse操作HDFS的时候遇到的一些问题,最近又想进一步学习学习Hadoop操 ...
- 原生Jdbc操作Mysql数据库开发步骤
原生Jdbc操作Mysql数据库开发步骤 原生的Jdbc就是指,不使用任何框架,仅用java.sql包下的方法实现数据库查询等的操作. 下面是开发步骤: 1.导入数据库驱动包 ...
- .NET Core Dapper操作mysql数据库
前言 现在ORM盛行,市面上已经出现了N款不同的ORM套餐了.今天,我们不谈EF,也不聊神马黑马,就说说 Dapper.如何在.NET Core中使用Dapper操作Mysql数据库呢,让我们跟随镜头 ...
随机推荐
- RS422接口与RS485接口
RS422具体接线参考网站 RS485接口 RS485设备为半双工设备,RS485收发器信号相关引脚包括控制引脚.485A.485B,其中控制引脚的高低电平决定当前处于接收模式还是发送模式. RS48 ...
- ASP.NET CORE 基础知识(一):概述【上】
此为系列文章,对MSDN ASP.NET Core 的官方文档进行系统学习与翻译.其中或许会添加本人对 ASP.NET Core 的浅显理解 原文请参考MSDN ASP.NET Core. 这篇文章是 ...
- Centos 7源码编译安装 php7.1 之生产篇
Centos 7源码编译安装 php7.1 之生产篇 Published 2017年4月30日 by Node Cloud 介绍: 久闻php7的速度以及性能那可是比php5系列的任何一版本都要快,具 ...
- devexpress layoutview
1.设定数据源 2.设置view 3.设置 templat cardview 4 显示
- SpringBoot 配置 Redis 多缓存名(不同缓存名缓存失效时间不同)
import com.google.common.collect.ImmutableMap; import org.springframework.cache.CacheManager; import ...
- Linux 笔记:文件名
文件名 Linux 系统区分英文字符的大小写.比如,myfile, Myfile 和 myFILE表示的是三个不同的文件.同样,用户密码和登录名也需要区分大小写(这里沿用了Unix 和 C 语言的命名 ...
- 2016-2017学年第三次测试赛 习题E 林喵喵算术
时间限制: 1 Sec 内存限制: 128 MB 提交: 70 解决: 25 提交统计讨论版 题目描述 给你两个八进制数,你需要在八进制计数法的情况下计算a-b. 如果结果为负数,你应该使用负号代 ...
- Myeclipse下PHP开发环境搭建及运行
外接CSDN链接 http://blog.csdn.net/yuxiangaaaaa/article/details/54948426 这是php初始设置,后面进行重新设置
- ConcurrentHashMap 结构 1.7 与1.8
1.结构 1.7 segment+HashEntity+Unsafe 1.8 移除Segment,使锁的粒度更小,Synchronized+CAS+Node+Unsafe 2. put() 1.7 先 ...
- 【原】Django总结
centos7下部署django详细步骤:https://www.cnblogs.com/djangocn/p/9538551.html 快速入门:https://www.cnblogs.com/ze ...