<?php
    //这是一个工具类;作用是完成对数据库的操作;
    class SqlHelper{
        public $conn;
        public $dbname="exam";
        public $username="root";
        public $password="123";
        public $host="192.168.1.100";

//构造函数(连接数据库);
        public function __construct(){
            $this->conn=mysql_connect($this->host,$this->username,$this->password);
            if(!$this->conn){
                die("连接失败".mysql_errno());
            }

    //设置字符编码;
            mysql_set_charset('utf8');
            mysql_select_db($this->dbname,$this->conn);
        }

//执行dql语句
        public function execute_dql($sql){
            $res=mysql_query($sql,$this->conn) or die(mysql_errno());
            return $res;
        }
        
        //执行dql语句,但是返回的是一个数组
        public function execute_dql2($sql){
            $arr=array();
            $res=mysql_query($sql,$this->conn) or die(mysql_errno());
            $i=0;
            //把$res的东西给$arr
            while($row=mysql_fetch_array($res)){
                $arr[$i]=$row;
                $i++;
            }
            //这里可以马上关闭;
            mysql_free_result($res);
            return $arr;
        }
        
        
        //执行dml语句
        public function execute_dml($sql){
            $b=mysql_query($sql,$this->conn) or die(mysql_errno());
            if(!$b){
                return 0;
            }else{
                if(mysql_affected_rows($this->conn)>0){
                    return 1;//表示只能执行成功
                }else {
                    return 2;//表示没有行受到影响;
                }
            }
        }
        
        
        //封装
        //考虑分页情况的查询
        //$sql="select * from where 表名 limit 0,6 ";
        //$sql="select count(*) from 表名";
        public function execute_dql_fenye($sql1,$sql2,$fenyePage){
            //得到分页的数据
            $res=mysql_query($sql1,$this->conn) or die (mysql_errno());
            //$res=>array();
            //将数据转移到数组
            $arr=array();
            while($row=mysql_fetch_assoc($res)){
                $arr[]=$row;
            }
            //释放资源
            mysql_free_result($res);
            //把数组赋值给$fenyePage
            $fenyePage->res_array=$arr;
            
            $res2=mysql_query($sql2,$this->conn) or die (mysql_errno());
            if($row=mysql_fetch_row($res2)){
                $fenyePage->pageCount=ceil($row[0]/$fenyePage->pageSize);
                $fenyePage->rowCount=$row[0];
            }
            mysql_free_result($res2);
            
            //把导航信息也封装到$fenyePage中;
            
            //显示上一页和下一页
            $navigate="";
            if($fenyePage->pageNow>1){
                $prePage=$fenyePage->pageNow-1;
                $navigate="<a href='{$fenyePage->gotoUrl}?pageNow=$prePage'>上一页</a>";
            }
            if($fenyePage->pageNow<$fenyePage->pageCount){
                $nextPage=$fenyePage->pageNow+1;
                $navigate.="<a href='{$fenyePage->gotoUrl}?pageNow=$nextPage'>下一页</a>";
            }
            
            //显示首页和末页
            $navigate.= "<a href='{$fenyePage->gotoUrl}?pageNow=1'>首页</a>";
            $navigate.= "<a href='{$fenyePage->gotoUrl}?pageNow=$fenyePage->pageCount'>末页</a>";
            
                 //显示当前页和共有多少页
            $navigate.= "当前页{$fenyePage->pageNow}/总共{$fenyePage->pageCount}页";

//以下显示多少页
            $page_whole=2;
            $start=floor(($fenyePage->pageNow-1)/$page_whole)*$page_whole+1;
            $index=$start;
            $min=floor(($fenyePage->pageCount-1)/$page_whole)*$page_whole;
            //向前整体翻页;
            //当前pageNow在10内,就没有翻页;
            if($fenyePage->pageNow>$page_whole){
                $navigate.= "<a href='{$fenyePage->gotoUrl}?pageNow=".($start-1)."'> <<</a>";
            }
            
            //如何定义start (1到10)(floor(pageNow-1)/10)*10+1; (11到20)(floor(pageNow-1/10))*10+1
            if($fenyePage->pageNow<=$min){
                for($start;$start<$index+$page_whole;$start++){
                    $navigate.="<a href='{$fenyePage->gotoUrl}?pageNow=$start'>[$start]</a>";
                }
            }else {
                for ($start;$start<=$fenyePage->pageCount;$start++){
                    $navigate.="<a href='{$fenyePage->gotoUrl}?pageNow=$start'>[$start]</a>";
                }
            }
                
            //向后整体翻页
            //向后翻页条显示条件;
            //
            //         $min=floor($pageCount-1/$page_whole)
            //
            //            if($pageNow<=$min*$pagewhole)
            //            
            if($fenyePage->pageNow<=$min){
            $navigate.= "<a href='{$fenyePage->gotoUrl}?pageNow=$start'> >> </a>";
            }
            
                
            $fenyePage->navigate=$navigate;
        }
        
        //关闭连接方式
        public function close_connect(){
            if(!empty($this->conn)){
                mysql_close($this->conn);
            }
        }
    }
?>

PHP原始的数据库操作的更多相关文章

  1. SQLite数据库操作 (原始操作)

    android提供了一个名为SQLiteDatabase的类,该类封装了一些操作数据库的API, 使用该类可以完成对数据进行添加(Create).查询(Retrieve).更新(Update)和删除( ...

  2. Python之路【第九篇】堡垒机基础&数据库操作

    复习paramiko模块 Python的paramiko模块,是基于SSH用于连接远程服务器并执行相关操作. SSHClient #!/usr/bin/env python #-*- coding:u ...

  3. laravel框架总结(七) -- 数据库操作

      1.使用DB门面进行基本操作 一旦你设置好了数据库连接,就可以使用 DB facade 来进行查找.DB facade 提供每个类型的查找方法:select.update.insert.delet ...

  4. Python之路【第八篇】:堡垒机实例以及数据库操作

    Python之路[第八篇]:堡垒机实例以及数据库操作   堡垒机前戏 开发堡垒机之前,先来学习Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作 SSHClient ...

  5. Python之路:堡垒机实例以及数据库操作

    一.堡垒机前戏 开发堡垒机之前,先学习Python的paramiko模块,该模块基于SSH用于连接远程服务器并执行相关操作. SSHClient 用于连接远程服务器并执行基本命令 基于用户名密码连接: ...

  6. 1-1hibernate数据库操作基础

    一.纯原始数据库连接详见http://www.cnblogs.com/lukelook/p/7845757.html 1.Class.forName("oracle.jdbc.driver. ...

  7. django的模型类管理器-----------数据库操作的封装

    模型实例方法 str():在将对象转换成字符串时会被调用. save():将模型对象保存到数据表中,ORM框架会转换成对应的insert或update语句. delete():将模型对象从数据表中删除 ...

  8. Qt: 数据库操作;

    QT的数据库操作有两种方式: 一) 使用QsqlTableModel类, 可以配合QTableView进行界面显示并进行数据库操作, 这种方法比较方便快捷: 二)  使用原始SQL语言, 利用INSE ...

  9. 【转载】微软官方提供的Sqlserver数据库操作帮助类SQLHelper类

    在.NET平台中,C#语言一般使用ADO.NET组件来操作Sqlserver数据库,通过ADO.NET组件可以实现连接数据库.查询数据集.执行SQL语句以及关闭数据库连接等操作,为此网上有很多开发者自 ...

随机推荐

  1. python学习第十八天 --错误&异常处理

    这一章节主要讲解python的错误和异常处理 什么是错误和异常?及其区别? 错误: 1.语法错误:代码不符合解释器或者编译器语法. 2.逻辑错误:不完整或者不合法输入或者计算出现问题.   异常:执行 ...

  2. 指针与数组、大小端之 printf("%x,%x,%x\n",*(a+1),ptr1[-1],*ptr2);

    在X86系统下,以下程序输出的值为多少? #include <stdio.h> #include <stdlib.h> int main(void) { ]={,,,,}; ) ...

  3. const int *p,int *const p区别(转)

    1)先从const int i说起.使用const修饰的i我们称之为符号常量.即,i不能在其他地方被重新赋值了.注意:const int i与int const i是等价的,相同的,即const与in ...

  4. 主题模型-LDA浅析

    (一)LDA作用 传统判断两个文档相似性的方法是通过查看两个文档共同出现的单词的多少,如TF-IDF等,这种方法没有考虑到文字背后的语义关联,可能在两个文档共同出现的单词很少甚至没有,但两个文档是相似 ...

  5. LeetCode_3 sum

    Given an array S of n integers, are there elements a, b, c ? Find all unique triplets in the array w ...

  6. PowerShell String对象方法 1

    PowerShell String对象方法 1 8 6月, 2013  在 Powershell tagged 字符串 / 对象 / 文本 by Mooser Lee 从之前的章节中,我们知道Powe ...

  7. Why Memory Barrier?

    引言:xchg做了什么? 首先,xchg eax, ecx并不会比mov edx, eax + mov eax, ecx + mov ecx, edx这三条指令加一起快,原因是xchg有副作用. Mi ...

  8. 转:linux执行shell脚本的方式及一些区别

    假设shell脚本文件为hello.sh放在/root目录下.下面介绍几种在终端执行shell脚本的方法: [root@localhost home]# cd /root/ [root@localho ...

  9. Windows Azure 存储管理器 (2014)

     Windows Azure存储用户经常希望能够在"管理器"中查看他们的数据,管理器指的是一款可用于显示存储帐户数据的工具.我们之前提供了我们所知的存储管理器列表.在本文中,我 ...

  10. 移动web开发研究

    1.jQuery Mobile jQuery Mobile框架能够帮助你快速开发出支持多种移动设备的Mobile应用用户界面.jQuery Mobile最新版本是1.4.0,默认主题采用扁平化设计风格 ...