Classe de ligação da base de dados PHP
estou a tentar obter um ID de utilizador a partir de uma base de dados dentro de uma classe, mas tenho muito pouca ou nenhuma experiência com aulas, como é que eu poderia ir para obter o uid do DB e, em seguida, devolver o uid?
Então, basicamente, algo assim.class hello {
public function getUid(){
//connect to the db
//get all of the users info
$array = mysql_fetch_array($result);
$uid = $array['uid'];
return $uid;
}
}
Como eu disse, Ainda sou novo nas aulas, por isso qualquer conselho ou ajuda seria muito apreciado!
Thanx adiantado!
10
6 answers
Primeiro construa uma biblioteca de classe MySQL... adequar os requisitos como nesta amostra:
<?php
include '../config/Dbconfig.php';
class Mysql extends Dbconfig {
public $connectionString;
public $dataSet;
private $sqlQuery;
protected $databaseName;
protected $hostName;
protected $userName;
protected $passCode;
function Mysql() {
$this -> connectionString = NULL;
$this -> sqlQuery = NULL;
$this -> dataSet = NULL;
$dbPara = new Dbconfig();
$this -> databaseName = $dbPara -> dbName;
$this -> hostName = $dbPara -> serverName;
$this -> userName = $dbPara -> userName;
$this -> passCode = $dbPara ->passCode;
$dbPara = NULL;
}
function dbConnect() {
$this -> connectionString = mysql_connect($this -> serverName,$this -> userName,$this -> passCode);
mysql_select_db($this -> databaseName,$this -> connectionString);
return $this -> connectionString;
}
function dbDisconnect() {
$this -> connectionString = NULL;
$this -> sqlQuery = NULL;
$this -> dataSet = NULL;
$this -> databaseName = NULL;
$this -> hostName = NULL;
$this -> userName = NULL;
$this -> passCode = NULL;
}
function selectAll($tableName) {
$this -> sqlQuery = 'SELECT * FROM '.$this -> databaseName.'.'.$tableName;
$this -> dataSet = mysql_query($this -> sqlQuery,$this -> connectionString);
return $this -> dataSet;
}
function selectWhere($tableName,$rowName,$operator,$value,$valueType) {
$this -> sqlQuery = 'SELECT * FROM '.$tableName.' WHERE '.$rowName.' '.$operator.' ';
if($valueType == 'int') {
$this -> sqlQuery .= $value;
}
else if($valueType == 'char') {
$this -> sqlQuery .= "'".$value."'";
}
$this -> dataSet = mysql_query($this -> sqlQuery,$this -> connectionString);
$this -> sqlQuery = NULL;
return $this -> dataSet;
#return $this -> sqlQuery;
}
function insertInto($tableName,$values) {
$i = NULL;
$this -> sqlQuery = 'INSERT INTO '.$tableName.' VALUES (';
$i = 0;
while($values[$i]["val"] != NULL && $values[$i]["type"] != NULL) {
if($values[$i]["type"] == "char") {
$this -> sqlQuery .= "'";
$this -> sqlQuery .= $values[$i]["val"];
$this -> sqlQuery .= "'";
}
else if($values[$i]["type"] == 'int') {
$this -> sqlQuery .= $values[$i]["val"];
}
$i++;
if($values[$i]["val"] != NULL) {
$this -> sqlQuery .= ',';
}
}
$this -> sqlQuery .= ')';
#echo $this -> sqlQuery;
mysql_query($this -> sqlQuery,$this ->connectionString);
return $this -> sqlQuery;
#$this -> sqlQuery = NULL;
}
function selectFreeRun($query) {
$this -> dataSet = mysql_query($query,$this -> connectionString);
return $this -> dataSet;
}
function freeRun($query) {
return mysql_query($query,$this -> connectionString);
}
}
?>
E o ficheiro de configuração...
<?php
class Dbconfig {
protected $serverName;
protected $userName;
protected $passCode;
protected $dbName;
function Dbconfig() {
$this -> serverName = 'localhost';
$this -> userName = 'root';
$this -> passCode = 'pass';
$this -> dbName = 'dbase';
}
}
?>
31
Author: Jaison Justus, 2015-04-05 14:40:13
Muito bem, um conselho:
Faz tudo por uma razão. Não uses coisas que não sabes. Vai e aprende antes.
Uma pessoa pode dar-lhe uma resposta para esta pergunta específica, mas até não saber o que orientado para o objecto meios e por que existemclasses não devias usá-los. 8
Author: galambalazs, 2010-07-12 13:01:02
- Criar duas classes. Um para trabalhar com base de dados, o segundo para gerenciar dados do usuário ou Auth.
- For SQL class create methods connect (), query (), fetch () etc
- Para A classe de Utilizador criar métodos get ($id) etc
4
Author: dwich, 2010-07-12 13:00:53
Há um problema com a forma como o seu código é escrito, não com a classe. Dê uma olhada mais de perto nesta linha:
$array = mysql_fetch_array($result);
Esta é a primeira vez que a variável $result
aparece na função. Portanto, não é possível comunicar com a base de dados.
Um possível pseudo-código seria:
- ligar ao servidor DB
- consulta a base de Dados
- busca os resultados
- devolve o campo
uid
.
Dê uma vista de olhos ao relevante documentação em primeiro lugar:
4
Author: Anax, 2010-07-12 13:04:27
Tente o seguinte:
ini_set("display_errors", 'off');
ini_set("error_reporting",E_ALL);
class myclass {
function myclass() {
$user = "root";
$pass = "";
$server = "localhost";
$dbase = "";
$conn = mysql_connect($server,$user,$pass);
if(!$conn)
{
$this->error("Connection attempt failed");
}
if(!mysql_select_db($dbase,$conn))
{
$this->error("Dbase Select failed");
}
$this->CONN = $conn;
return true;
}
function close() {
$conn = $this->CONN ;
$close = mysql_close($conn);
if(!$close)
{
$this->error("Connection close failed");
}
return true;
} function sql_query($sql="") {
if(empty($sql))
{
return false;
}
if(empty($this->CONN))
{
return false;
}
$conn = $this->CONN;
$results = mysql_query($sql,$conn) or die("Query Failed..<hr>" . mysql_error());
if(!$results)
{
$message = "Bad Query !";
$this->error($message);
return false;
}
if(!(eregi("^select",$sql) || eregi("^show",$sql)))
{
return true;
}
else
{
$count = 0;
$data = array();
while($row = mysql_fetch_array($results))
{
$data[$count] = $row;
$count++;
}
mysql_free_result($results);
return $data;
}
}
}
$obj = new myclass();
$obj->sql_query("");
3
Author: Patel, 2013-07-17 09:28:59
Pode usar uma classe de base de dados personalizada.
Código :
<?php
Class Database
{
private $user ;
private $host;
private $pass ;
private $db;
public function __construct()
{
$this->user = "root";
$this->host = "localhost";
$this->pass = "";
$this->db = "db_blog";
}
public function connect()
{
$link = mysql_connect($this->user, $this->host, $this->pass, $this->db);
return $link;
}
}
?>
1
Author: rashedcs, 2017-08-18 07:09:40