本文整理汇总了PHP中Query::generateSelectStm方法的典型用法代码示例。如果您正苦于以下问题:PHP Query::generateSelectStm方法的具体用法?PHP Query::generateSelectStm怎么用?PHP Query::generateSelectStm使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Query
的用法示例。
在下文中一共展示了Query::generateSelectStm方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: loadFeedback
function loadFeedback()
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineFeedbackColumns();
$table = Query::getDBSchema()->getTable(TABLE_FEEDBACK);
$db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(FEEDBACK_SUBJECT), Operator::EQUAL, $this->getID())), array()));
if ($db->num_rows() > 0) {
require_once "strings/strings.php";
$fb = FEEDBACK_INITIAL_VALUE;
while ($row = $db->fetch_result()) {
$fb += intval($row[FEEDBACK_VALUE]) > 0 ? 1 : -1;
//se sul DB è 0 allora è -1 se è positivo allora +1;
}
return $this->setFeedback($fb);
} else {
if ($db->errno()) {
$db->display_error("User::loadFeedback()");
}
}
} else {
$db->display_connect_error("User::loadFeedback()");
}
return $this->setFeedback(FEEDBACK_INITIAL_VALUE);
}
示例2: loadFollows
function loadFollows()
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineFollowColumns();
$table = Query::getDBSchema()->getTable(TABLE_FOLLOW);
$db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(FOLLOW_FOLLOWER), Operator::EQUAL, $this->getID())), array()));
if ($db->num_rows() > 0) {
$fols = array();
while ($row = $db->fetch_result()) {
define_tables();
defineFollowColumns();
$f = self::loadFromDatabase(intval($row[FOLLOW_SUBJECT]), false);
if ($f !== false) {
$fols[$f->getID()] = $f;
}
}
return $this->setFollows($fols);
} else {
if ($db->errno()) {
$db->display_error("User::loadFollows()");
}
}
} else {
$db->display_connect_error("User::loadFollows()");
}
return $this->setFollows(array());
}
示例3: getCount
function getCount($object)
{
parent::load($object);
$objectClass = get_class($object);
$rs = $this->db->execute($s = Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(REPORT_OBJECT_ID), Operator::EQUAL, $object->getID()), new WhereConstraint($this->table->getColumn(REPORT_OBJECT_CLASS), Operator::EQUAL, get_class($object))), array("count" => 2)));
if ($this->db->num_rows() != 1) {
throw new Exception("Si è verificato un errore. Riprovare.");
}
$row = $this->db->fetch_row();
return intval($row[0]);
}
示例4: loadByNickname
function loadByNickname($nickname)
{
parent::load($nickname);
$this->db->execute($s = Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(DB::USER_NICKNAME), Operator::EQUAL, $nickname)), array()));
if ($this->db->num_rows() != 1) {
throw new Exception("L'oggetto cercato non è stato trovato. Riprovare.");
}
$row = $this->db->fetch_result();
$user = $this->createFromDBRow($row);
return $user;
}
示例5: loadForAuthor
function loadForAuthor($author)
{
parent::load($author);
if (!is_subclass_of($post, "User")) {
throw new Exception("Attenzione! Il parametro di ricerca non è un utente.");
}
$this->db->execute(Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(DB::RESOURCE_OWNER), Operator::EQUAL, intval($author->getID()))), array()));
$resources = array();
while ($row = $db->fetch_result()) {
$resources[] = $this->createFromDBRow($row);
}
return $resources;
}
示例6: loadAll
function loadAll($post)
{
parent::load($post);
if (!is_subclass_of($post, "Post")) {
throw new Exception("Attenzione! Il parametro di ricerca non è un post.");
}
$rs = $this->db->execute($s = Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(DB::COMMENT_POST), Operator::EQUAL, intval($post->getID()))), array()), $this->table->getName(), $this);
$comm = array();
if ($this->db->num_rows() > 0) {
while ($row = $this->db->fetch_result()) {
$c = new Comment($row[DB::COMMENT_COMMENT], intval($row[DB::COMMENT_POST]), intval($row[DB::COMMENT_AUTHOR]));
$com->setID($row[DB::COMMENT_ID])->setCreationDate(date_timestamp_get(date_create_from_format("Y-m-d G:i:s", $row[DB::COMMENT_CREATION_DATE])));
$comm[] = $com;
}
}
return $post->setComments($comm);
}
示例7: save
function save($post, $author, $vote)
{
parent::save($post, "Post");
parent::save($author, "User");
settype($vote, "boolean");
//elimino il vecchio voto
$this->db->execute(Query::generateDeleteStm($this->table, array(new WhereConstraint($this->table->getColumn(DB::VOTE_AUTHOR), Operator::EQUAL, intval($author->getID()), new WhereConstraint($this->table->getColumn(DB::VOTE_POST), Operator::EQUAL, intval($post->getID()))))), $this->table->getName(), array($author->getID(), $post->getID()));
//non controllo se è stato cancellato perché può non esserci
$data = array(DB::VOTE_VOTE => $vote ? 1 : 0, DB::VOTE_POST => intval($post->getID()), DB::VOTE_AUTHOR => intval($author->getID()));
$this->db->execute($s = Query::generateInsertStm($this->table, $data), $this->table->getName(), $data);
if ($this->db->affected_rows() != 1) {
throw new Exception("Si è verificato un errore salvando l'oggetto. Riprovare.");
}
//carico il voto inserito.
$this->db->execute($s = Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(DB::VOTE_AUTHOR), Operator::EQUAL, intval($author->getID()), new WhereConstraint($this->table->getColumn(DB::VOTE_POST), Operator::EQUAL, intval($post->getID())))), array()), $this->table->getName(), $data);
if ($this->db->num_rows() != 1) {
throw new Exception("Si è verificato un errore salvando l'oggetto. Riprovare.");
}
return true;
}
示例8: tagExists
/**
* Controlla l'esistenza di un tag
* @param string $tag il nome di un tag.
* @return TRUE se il tag esiste già nel sistema, FALSE altrimenti.
*/
static function tagExists($tag)
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineTagColumns();
$table = Query::getDBSchema()->getTable(TABLE_TAG);
$data = array(TAG_NAME => $tag);
$db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(TAG_NAME), Operator::EQUAL, $tag)), array()));
if ($db->num_rows() == 1) {
return true;
} else {
return false;
}
} else {
$db->display_connect_error("TagManager::tagExists()");
}
return false;
}
示例9: loadFromDatabase
/**
* Crea un voto caricando i dati dal database.
* È come fare una ricerca sul database e poi fare new Vote().
*
* @param $id: l'ID del voto da caricare.
* @return: il voto caricato o FALSE se non lo trova.
*/
static function loadFromDatabase($author, $post)
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
require_once 'strings/strings.php';
define_tables();
defineVoteColumns();
$table = Query::getDBSchema()->getTable(TABLE_VOTE);
$rs = $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(VOTE_AUTHOR), Operator::EQUAL, $author), new WhereConstraint($table->getColumn(VOTE_POST), Operator::EQUAL, $post)), array()), $table->getName(), null);
if ($db->num_rows() == 1) {
$row = $db->fetch_result();
$v = new Vote(intval($row[VOTE_AUTHOR]), intval($row[VOTE_POST]), $row[VOTE_VOTE] > 0);
$v->setCreationDate(date_timestamp_get(date_create_from_format("Y-m-d G:i:s", $row[VOTE_CREATION_DATE])));
return $v;
}
//else $db->display_error("Vote::loadFromDatabase()");
} else {
$db->display_connect_error("Vote::LoadFromDatabase()");
}
return false;
}
示例10: searchPostsBy
private static function searchPostsBy($keys, $options, $echo_query = false)
{
require_once "query.php";
require_once "strings/strings.php";
define_tables();
definePostColumns();
$table = Query::getDBSchema()->getTable(TABLE_POST);
$loadComments = true;
$wheres = array();
foreach ($keys as $key => $value) {
if ($key == "name" || $key == "title") {
$wheres[] = new WhereConstraint($table->getColumn(POST_TITLE), Operator::LIKE, "%" . Filter::filterText($value) . "%");
}
if ($key == "permalink") {
$wheres[] = new WhereConstraint($table->getColumn(POST_PERMALINK), Operator::EQUAL, intval($value));
}
if ($key == "id") {
$wheres[] = new WhereConstraint($table->getColumn(POST_ID), Operator::EQUAL, intval($value));
}
if ($key == "tag") {
$wheres[] = new WhereConstraint($table->getColumn(POST_TAGS), Operator::LIKE, "%" . Filter::filterText($value) . "%");
}
if ($key == "day") {
if (!is_numeric($value)) {
$value = date_timestamp_get(date_create_from_format("Y-m-d", $value));
}
$daystart = date("Y-m-d", $value);
$dayend = date("Y-m-d", $value + 24 * 60 * 60);
//echo "<br />" . $daystart . "-" . $dayend; //DEBUG
$wheres[] = new WhereConstraint($table->getColumn(POST_CREATION_DATE), Operator::GREATEROREQUAL, $daystart);
$wheres[] = new WhereConstraint($table->getColumn(POST_CREATION_DATE), Operator::LESSER, $dayend);
}
if ($key == "category") {
$wheres[] = new WhereConstraint($table->getColumn(POST_CATEGORIES), Operator::LIKE, "%" . Filter::filterText($value) . "%");
}
if ($key == "title") {
$wheres[] = new WhereConstraint($table->getColumn(POST_TITLE), Operator::LIKE, "%" . Filter::filterText($value) . "%");
}
if ($key == "content") {
$wheres[] = new WhereConstraint($table->getColumn(POST_CONTENT), Operator::LIKE, "%" . Filter::filterText($value) . "%");
}
if ($key == "author") {
$wheres[] = new WhereConstraint($table->getColumn(POST_AUTHOR), Operator::EQUAL, intval($value));
}
if ($key == "no_id") {
$wheres[] = new WhereConstraint($table->getColumn(POST_ID), Operator::NOTEQUAL, intval($value));
}
if ($key == "loadComments") {
$loadComments = $value == true;
}
}
$newopt = array();
foreach ($options as $key => $value) {
if ($key == "by") {
if (!is_array($value)) {
$value = array($value);
}
$newvalue = array();
foreach ($value as $column) {
if (!is_a($column, "Column")) {
$column = $table->getColumn($column);
}
if (!is_null($column)) {
$newvalue[] = $column;
}
}
$value = $newvalue;
}
$newopt[$key] = $value;
}
$db = new DBManager();
$db->execute($s = Query::generateSelectStm(array($table), array(), $wheres, $newopt));
if ($echo_query) {
echo "<font color='red'>" . $s . "</font>";
}
//DEBUG
$posts = array();
while ($row = $db->fetch_result()) {
require_once "post/Post.php";
$posts[] = Post::createFromDBResult($row, $loadComments);
}
return $posts;
}
示例11: permalinkExists
function permalinkExists($permalink)
{
parent::load($permalink);
$rs = $this->db->execute($s = Query::generateSelectStm(array($this->table), array(), array(new WhereConstraint($this->table->getColumn(DB::POST_PERMALINK), Operator::EQUAL, $permalink)), array("count" => 2)));
if ($this->db->num_rows() != 1) {
throw new Exception("Si è verificato un errore. Riprovare.");
}
$row = $this->db->fetch_row();
return $row[0] > 0;
}
示例12: getAccessCount
/**
* @deprecated
* Enter description here ...
* @param unknown_type $type
* @param unknown_type $id
*/
static function getAccessCount($type, $id)
{
if ($type == null || $type == "" || $id == null) {
return 0;
}
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineLogColumns();
$table = Query::getDBSchema()->getTable("AccessLog");
$exists = false;
if ($type == "Post") {
require_once 'post/PostManager.php';
return 0;
$exists = PostManager::postExists($id);
} else {
if ($type == "User") {
require_once 'user/UserManager.php';
return 0;
$exists = UserManager::userExists($id);
} elseif ($type == "Partner") {
//TODO: implementa Partner
// require_once 'post/PartnerManager.php';
// $exists = PartnerManager::partnerExists($id);
}
}
if ($exists) {
$wheres = array(new WhereConstraint($table->getColumn("alog_type"), Operator::EQUAL, $type), new WhereConstraint($table->getColumn("alog_id"), Operator::EQUAL, $id));
$db->execute($s = Query::generateSelectStm(array($table), array(), $wheres, array()));
if ($db->num_rows() == 1) {
$row = $db->fetch_result();
$data = array("alog_count" => ++$row["alog_count"]);
$db->execute($s = Query::generateUpdateStm($table, $data, $wheres), null, LOGMANAGER);
if ($db->affected_rows() == 1) {
return $row["alog_count"];
}
} else {
$data = array("alog_type" => $type, "alog_id" => $id);
$db->execute($s = Query::generateInsertStm($table, $data));
if ($db->affected_rows() == 1) {
}
return 1;
}
}
return 0;
}
}
示例13: loadMailsFromUser
static function loadMailsFromUser($user)
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineMailColumns();
$table = Query::getDBSchema()->getTable(TABLE_MAIL);
$db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(MAIL_FROM), Operator::EQUAL, $user)), array()), $table->getName(), $this);
//echo "<p>" . $s . "</p>"; //DEBUG
//echo "<p>" . $db->num_rows() . "</p>"; //DEBUG
if ($db->num_rows() == 1) {
// echo serialize(mysql_fetch_assoc($rs)); //DEBUG
$mails = array();
while ($row = $db->fetch_result()) {
$data = array("text" => $row[MAIL_TEXT], "subject" => $row[MAIL_SUBJECT], "from" => intval($row[MAIL_FROM]), "to" => $row[MAIL_TO], "repliesTo" => $row[MAIL_REPLIES_TO]);
$m = new Mail($data);
$m->setID(intval($row[MAIL_ID]))->setCreationDate(date_timestamp_get(date_create_from_format("Y-m-d G:i:s", $row[MAIL_CREATION_DATE])));
$mails[] = $m;
}
//echo "<p>" .$m ."</p>";
return $mails;
} else {
$db->display_error("Mail::loadMailsFromUser()");
}
} else {
$db->display_connect_error("Mail::loadMailsFromUser()");
}
return false;
}
示例14: loadReports
/**
* Carica in this i report recuperati dal database per questo post (deve avere un ID!).
*/
function loadReports()
{
require_once "query.php";
$db = new DBManager();
if (!$db->connect_errno()) {
define_tables();
defineReportColumns();
$table = Query::getDBSchema()->getTable(TABLE_REPORT);
$rs = $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(REPORT_POST), Operator::EQUAL, $this->getID())), array()), $table->getName(), $this);
if ($rs !== false) {
$reports = array();
while ($row = $db->fetch_result()) {
require_once "common.php";
$report = new Report(intval($row[REPORT_USER]), intval($row[REPORT_POST]), $row[REPORT_TEXT]);
$report->setID($row[REPORT_ID]);
$reports[] = $report;
}
$this->setReports($reports);
} else {
if ($db->errno()) {
$db->display_error("Post::loadReports()");
}
}
} else {
$db->display_connect_error("Post::loadReports()");
}
return $this;
}
示例15: loadAll
function loadAll()
{
$loadA = $this->loadAccessCount;
$this->loadAccessCount = false;
parent::checkConnection();
$s = "SELECT * from " . DB::TABLE_CATEGORY . " WHERE " . DB::CATEGORY_NAME . " NOT IN (SELECT DISTINCT " . DB::SUB_CATEGORY_CATEGORY . " FROM " . DB::TABLE_SUB_CATEGORY . ")";
$this->db->execute(Query::generateSelectStm(array($this->table, $this->table_sc), array(new JoinConstraint($this->table->getColumn(DB::CATEGORY_NAME), $this->table_sc->getColumn(DB::SUB_CATEGORY_CATEGORY))), array(), array()));
$this->db->execute($s);
$cat = array();
$res = $this->db->fetch_all_results();
foreach ($res as $row) {
$cat[] = $this->createFromDBRow($row);
}
return $cat;
}