单例模式的用途,可用于数据库操作

<?php

Class Db
{
static private $whe;//条件
static private $tab;//表名
static private $lim;//分段变量
static private $order_by;//排序
private $str_key = array();//添加数据的键
private $str_val = array();//添加数据的值
private $key_val = array();//修改的数据
//防止外部实例对象
private function __construct(){}
//防止克隆
private function __clone(){} //唯一一个实例对象
static public $new_obj;
static public function table($t)
{
if (!self::$new_obj) {
self::$new_obj = new Db;
}
self::$tab=$t;
return self::$new_obj;
}
//链接数据库
public function mysql_connect()
{
$mysql_conf = array(
'host'=>'127.0.0.1:3306',//连接地址
'db'=>'test',//库名
'db_user'=>'root',//账号
'db_pwd'=>'root'//密码
);
return new MySQLi($mysql_conf['host'] , $mysql_conf['db_user'], $mysql_conf['db_pwd'] ,$mysql_conf['db']);//创建一个mysqli对象
} //条件
public function where($cond)
{
if (isset($cond)) {
self::$whe = ' where '.$cond;
}
return $this;
} //分页
public function limit($l)
{
if (isset($l)) {
self::$lim = ' limit '.$l;
}
return $this;
} //排序
public function order($odr)
{
self::$order_by = ' order by '. $odr;
return $this;
}
//查询语句
public function sql_select()
{
//准备一条SQL语句
return "select * from ".self::$tab.self::$order_by.self::$whe;
} //查询多条语句
public function select()
{
$reslut = mysqli_query($this->mysql_connect(),$this->sql_select().self::$lim);//也可以这么写:$this->mysql_connect()->query($this->sql_select().self::$lim);
$attr = $reslut->fetch_all(MYSQL_ASSOC);//MYSQL_ASSOC带数据库索引 MYSQL_NUM数值维索引 MYSQL_BOTH数值索引、数据库索引都有
return $attr;
} //查询单条语句
public function find()
{
$reslut = $this->mysql_connect()->query($this->sql_select());
$attr = $reslut->fetch_row(MYSQL_ASSOC);
return $attr;
} //添加或修改字段
public function data(Array $data)
{
if (!empty($data)) { foreach ($data as $key => $value) {
//添加的数据
$this->str_key[] = $key;
$this->str_val[] = $value;
//修改的数据
$this->key_val[] = is_string($value) ? $key.'= "'.$value.'"' : $key.'='.$value;
}
return $this;
}
} //添加字段
public function insert()
{ if (!isset($this->str_key) or !isset($this->str_val)) {
return 'error';
}else{
$key = implode(',', $this->str_key);
$val = implode(',', $this->str_val);
$mysql_content = 'insert into '.self::$tab.' ('.$key.') values('.$val.')';
$reslut =$this->mysql_connect()->query($mysql_content);
return $reslut;
}
} //修改字段
public function update()
{
if (!$this->key_val) {
return 'error';
}else{
$k_v = implode(', ',$this->key_val);
$mysql_content = 'update '.self::$tab.' set '.$k_v.' '.self::$whe;
$reslut =$this->mysql_connect()->query($mysql_content);
return $reslut;
}
} //删除字段
public function delete()
{
$mysql_content = 'delete from '.self::$tab.self::$whe;
$reslut =$this->mysql_connect()->query($mysql_content);
return $reslut;
} }
?>

下面是调用这个类

<?php
@include('./model.php');
//单条查询
$test = Db::table('test')->where('id=3')->find();
var_dump($test);
//分页查询
// $test1 = Db::table('test')->limit('0,2')->select();
// var_dump($test1);
//多条查询
// $test2 = Db::table('test')->order('id asc')->select();
// var_dump($test2);
//添加
// $test3 = Db::table('test')->data(['i'=>3,'age'=>6,'sex'=>9])->insert();
// var_dump($test3);
// 修改
// $test4 = Db::table('test')->where('id=30')->data(['IDinfo'=>789,'newid'=>456])->update();
// var_dump($test4);
// 删除
// $test5 = Db::table('test')->where('id>11')->delete();
// var_dump($test5);
?>

单例模式写MySQL model类,简单的增、删、改、查的更多相关文章

  1. Android SQLite(1)简单示例-增,删,改,查

    1.主要核心类,Sqlite编程要继承SQLiteOpenHelper import android.content.Context; import android.database.sqlite.S ...

  2. python学习-62 类属性的增 删 该 查

    类属性 1.类属性 类属性又称为静态变量,或者是静态数据.这些数据是与它们所属的类对象绑定的,不依赖于任何类实例. 2.增 删 改 查 class zoo: country = 'china' def ...

  3. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  4. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  5. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  6. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  7. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  8. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  9. 简单的php数据库操作类代码(增,删,改,查)

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

随机推荐

  1. linux下反弹shell

    01 前言 CTF中一些命令执行的题目需要反弹shell,于是solo一波. 02 环境 win10      192.168.43.151       监听端    装有nc kali        ...

  2. 文字创作类App分享-简书

    今天我用Mockplus做了一套简书App的原型,这是一款文字创作类的App,用户通过写文.点赞等互动行为,提高自己在社区的影响力,打造个人品牌.我运用了Mockplus基础组件.交互组件.移动组件等 ...

  3. JavaScript 排序算法

    排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个对象呢?直接比较数学上的大小是没有意义的,因此,比较的 ...

  4. Django haystack+solr搜索引擎部署的坑.

    跟着<<Django by Example>> 一路做下来,到了搭建搜索引擎的步骤 默认的思路是用 obj.objects.filter(body__icontains='fr ...

  5. merge and saveorupdate

    首先 saveOrUpdate返回void 也就是什么都不返回 而merge会返回一个对象 merge 在执行session.merge(a)代码后,a对象仍然不是持久化状态,a对象仍然不会被关联到S ...

  6. JAVA 8 主要新特性 ----------------(四)Lambda函数式接口

    一.什么是函数式接口 只包含一个抽象方法的接口,称为函数式接口.  你可以通过 Lambda 表达式来创建该接口的对象.(若 Lambda 表达式抛出一个受检异常,那么该异常需要在目标接口的抽象方法 ...

  7. Java变成思想总结

    Java容器 collection一个独立的元素序列,这些元素都服从一条或多条规则.list必须按照插入的顺序保存元素,set不能有重复元素,queue按照排队的顺序确定对象产生的顺序.map一组成对 ...

  8. 如果你要查看文件的每个部分是谁修改的, 那么 git blame 就是不二选择

    原文: http://gitbook.liuhui998.com/5_5.html 如果你要查看文件的每个部分是谁修改的, 那么 git blame 就是不二选择. 只要运行'git blame [f ...

  9. Runtime之实例总结

    通过前面几篇对Runtime的讲解,本篇汇总一下Runtime实际中常用的一些场景. 1.获取类的基本信息 获取类名: const char *className = class_getName(cl ...

  10. tar与压缩详解

    .gz  gzip   gunzip(gzip -d) .zip .rar .bz2 gzip压缩文件不保留原文件 , 不能压缩目录 gzip   filename.x   用gzip压缩文件 gun ...