Php Mssql操作简单封装支持存储过程

前端之家收集整理的这篇文章主要介绍了Php Mssql操作简单封装支持存储过程前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

核心代码

PHP;"> PHP /* * class :Mssql * time :2009-12-10 * author :Libaochang * version :1.0b * description :mssql database access class,it can execute the procedur or sql */ class MssqlUtil { var $user = null; //database user name var $keys = null; //database user password var $host = 'localhost'; //database host name/ip and port var $base = null; //database name var $link = null; //create link

/**

  • construct function init all parmeters
  • @param @H_404_2@ $host database host name/ip and port
  • @param @H_404_2@ $user database user name
  • @param @H_404_2@ $keys database user password
  • @param @H_404_2@ $base database name
    */
    function __construct($host,$user,$keys,$base) {
    $this->host = $host;
    $this->user = $user;
    $this->keys = $keys;
    $this->base = $base;
    }
    /**
  • create the connection
    */
    function connect() {
    $this->link = mssql_connect($this->host,$this->user,$this->keys);
    if (!$this->link) {
    die('connecting Failed...check the module and setting...');
    }
    $select = mssql_select_db($this->base,$this->link);
    if (!$select) {
    die('data base is not exist...,please checke it ...');
    }
    }
    /**
  • execute the procedur width the parameter
  • @param @H_404_2@ $pName procedur name
  • @param @H_404_2@ $parName parameters it's like this $par=array('@a'=>'a')
  • @param @H_404_2@ $sqlTyle the procedur's parameter type,it's llike this $sqlType=array(sqlVARCHAR,sqlVARCHAR); and there is not the char single quote mark(').
  • @return @H_404_2@ object array
    */
    function executeProcedur($pName,$parName,$sqlTyle) {
    $this->connect();
    $stmt = mssql_init($pName,$this->link);
    if (isset($parName)) {
    $i = 0;
    foreach ($parName as $par => $value) {
    mssql_bind($stmt,$par,$value,$sqlTyle[$i]);
    ++$i;
    }
    $res = mssql_execute($stmt);
    $this->close();
    while ($row = mssql_fetch_assoc($res)) {
    $r[] = $row;
    }
    unset($i);
    mssql_free_result($res);
    mssql_free_statement($stmt);
    return $r;
    }
    }
    /**
  • execute procedur without the parameter
  • @param @H_404_2@ $pName Procedur Name
  • @return @H_404_2@ object array
    */
    function executeProcedurNoPar($pName) {
    $this->connect();
    $stmt = mssql_init($pName,$this->link);
    $res = mssql_execute($stmt);
    $this->close();
    while ($row = mssql_fetch_assoc($res)) {
    $r[] = $row;
    }
    mssql_free_result($res);
    mssql_free_statement($stmt);
    return $r;
    }
    /**
  • Get one row return Array
  • @param @H_404_2@ $sql
  • @return @H_404_2@ Array
    */
    function getRowArray($sql) {
    $res = $this->query($sql);
    $r = mssql_fetch_row($res);
    mssql_free_result($res);
    return $r;
    }
    /**
  • Get one row return object
  • @param @H_404_2@ $sql sql
  • @return @H_404_2@ Object
    */
    function getRowObject($sql) {
    $res = $this->query($sql);
    $r = mssql_fetch_assoc($res);
    return $r;
    }
    /**
  • Execute one sql
  • @param @H_404_2@ $sql sql
  • @return @H_404_2@ result
    */
    function query($sql) {
    $this->connect();
    $res = mssql_query($sql,$this->link);
    $this->close();
    return $res;
    }
    /**
  • Get every row from result by Object,Return a Array with every element is Object
  • @param @H_404_2@ $sql
  • @return @H_404_2@ Object Array result
    */
    function getResult($sql) {
    $res = $this->query($sql);
    while ($row = mssql_fetch_assoc($res)) {
    $r[] = $row;
    }
    unset($row);
    mssql_free_result($res);
    return $r;
    }
    /**
  • execute a sql
  • @param @H_404_2@ $sql sql
    */
    function executesql($sql) {
    return $this->query($sql);
    }
    /**
  • execute a sql statement
  • @param @H_404_2@ $sql
  • @return @H_404_2@ int $affected rows
    */
    function querysql($sql) {
    $this->connect();
    mssql_query($sql,$this->link);
    $affected = mssql_rows_affected($this->link);
    $this->close();
    return $affected;
    }
    /**
  • close connection
    */
    function close() {
    mssql_close();
    }
    }
    ?>

下面说下调用

PHP;"> function __autoload($MssqlUtil) { require $MssqlUtil.'.PHP'; } $db = new MssqlUtil($config['host'],$config['user'],$config['keys'],$config['base']);

主要说下带参数的存储过程调用

'a') @a 为存储过程里面的参数,a为要传递的值 $sqlTyle 是存储过程参数的数据类型,是数组形式,也很重要 array(sqlCHAR,sqlVARCHAR),注意不要加单引号等,因为sqlVARCHAR是sql的一些常量

带参数存储过程
$db->executeProcedur($pName,$sqlTyle);
无参数存储过程
$db->executeProcedurNoPar($pName);

select * from t2 where t2.id in(select max(t2.id) from t1 join t2 on t1.id = t2.pid group by t1.id); 取每个分类的最新一条数据。此处做个记录。 t1为类别表,t2为主表

猜你在找的PHP相关文章