本文整理匯總了PHP中DBUtil::selectScalar方法的典型用法代碼示例。如果您正苦於以下問題:PHP DBUtil::selectScalar方法的具體用法?PHP DBUtil::selectScalar怎麽用?PHP DBUtil::selectScalar使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類DBUtil
的用法示例。
在下文中一共展示了DBUtil::selectScalar方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: contentGetNextRevisionNumber
protected function contentGetNextRevisionNumber($pageId)
{
$pageId = (int) $pageId;
$tables = DBUtil::getTables();
$historyTable = $tables['content_history'];
$historyColumn = $tables['content_history_column'];
$sql = "\n SELECT MAX({$historyColumn['revisionNo']})\n FROM {$historyTable}\n WHERE {$historyColumn['pageId']} = {$pageId}";
// FIXME: how to avoid concurrency problems?
$pos = DBUtil::selectScalar($sql);
return $pos === null ? 1 : (int) $pos + 1;
}
示例2: contentGetLastContentPosition
protected function contentGetLastContentPosition($pageId, $contentAreaIndex)
{
$pageId = (int) $pageId;
$contentAreaIndex = (int) $contentAreaIndex;
$table = DBUtil::getTables();
$contentTable = $table['content_content'];
$contentColumn = $table['content_content_column'];
$sql = "\n SELECT MAX({$contentColumn['position']})\n FROM {$contentTable}\n WHERE {$contentColumn['pageId']} = {$pageId}";
$pos = DBUtil::selectScalar($sql);
return $pos === null ? -1 : (int) $pos;
}
示例3: insertPage
public function insertPage($args)
{
$pageId = (int) $args['pageId'];
$position = (int) $args['position'];
$parentPageId = (int) $args['parentPageId'];
$dbtables = DBUtil::getTables();
$pageTable = $dbtables['content_page'];
$pageColumn = $dbtables['content_page_column'];
$sql = "
UPDATE $pageTable
SET $pageColumn[position] = $pageColumn[position]+1
WHERE $pageColumn[parentPageId] = $parentPageId
AND $pageColumn[position] >= $position";
DBUtil::executeSQL($sql);
// *** Update all left/right values for all pages "right of this page"
// Assume "this page" has left/right values that matches it's subtree (but with a wrong offset)
$pageData = DBUtil::selectObjectByID('content_page', $pageId);
if ($parentPageId > 0) {
$parentPageData = DBUtil::selectObjectByID('content_page', $parentPageId);
$parentLevel = $parentPageData['level'];
} else {
$parentPageData = null;
$parentLevel = -1;
}
// Fetch largest left/right value left of this page's new position
$sql = "
SELECT MAX($pageColumn[setRight])
FROM $pageTable
WHERE $pageColumn[parentPageId] = $parentPageId
AND $pageColumn[position] < $position
AND $pageColumn[id] != $pageId";
$maxLeftOfthis = DBUtil::selectScalar($sql);
if (empty($maxLeftOfthis)) {
$maxLeftOfthis = -1;
}
if ($parentPageData != null && $parentPageData['setLeft'] > $maxLeftOfthis) {
$maxLeftOfthis = $parentPageData['setLeft'];
}
$diff = $pageData['setRight'] - $pageData['setLeft'] + 1;
$sql = "
UPDATE $pageTable SET
$pageColumn[setRight] = $pageColumn[setRight]+$diff
WHERE $pageColumn[setRight] > $maxLeftOfthis AND $pageColumn[id] != $pageId";
DBUtil::executeSQL($sql);
$sql = "
UPDATE $pageTable SET
$pageColumn[setLeft] = $pageColumn[setLeft]+$diff
WHERE $pageColumn[setLeft] > $maxLeftOfthis AND $pageColumn[id] != $pageId";
DBUtil::executeSQL($sql);
// *** Update level/left/right values for this page and all pages below
$levelDiff = $pageData['level'] - ($parentLevel + 1);
$diff2 = $pageData['setLeft'] - $maxLeftOfthis - 1;
//echo "diff2=$diff2. ";
$sql = "
UPDATE $pageTable SET
$pageColumn[setLeft] = $pageColumn[setLeft]-$diff2,
$pageColumn[setRight] = $pageColumn[setRight]-$diff2,
$pageColumn[level] = $pageColumn[level]-$levelDiff
WHERE $pageData[setLeft] <= $pageColumn[setLeft] AND $pageColumn[setRight] <= $pageData[setRight]";
DBUtil::executeSQL($sql);
// Update this page
$newPageData = array('id' => $pageId, 'position' => $position, 'parentPageId' => $parentPageId, 'level' => ($parentPageData == null ? 0 : $parentPageData['level'] + 1));
DBUtil::updateObject($newPageData, 'content_page');
return true;
}
示例4: contentGetLastContentPosition
protected function contentGetLastContentPosition($pageId, $contentAreaIndex)
{
$pageId = (int) $pageId;
$contentAreaIndex = (int) $contentAreaIndex;
$table = DBUtil::getTables();
$contentTable = $table['content_content'];
$contentColumn = $table['content_content_column'];
$sql = "
SELECT MAX($contentColumn[position])
FROM $contentTable
WHERE $contentColumn[pageId] = $pageId";
$pos = DBUtil::selectScalar($sql);
return $pos === null ? -1 : (int) $pos;
}
示例5: insertPage
public function insertPage($args)
{
$pageId = (int) $args['pageId'];
$position = (int) $args['position'];
$parentPageId = (int) $args['parentPageId'];
$dbtables = DBUtil::getTables();
$pageTable = $dbtables['content_page'];
$pageColumn = $dbtables['content_page_column'];
$sql = "\n UPDATE {$pageTable}\n SET {$pageColumn['position']} = {$pageColumn['position']}+1\n WHERE {$pageColumn['parentPageId']} = {$parentPageId}\n AND {$pageColumn['position']} >= {$position}";
DBUtil::executeSQL($sql);
// *** Update all left/right values for all pages "right of this page"
// Assume "this page" has left/right values that matches it's subtree (but with a wrong offset)
$pageData = DBUtil::selectObjectByID('content_page', $pageId);
if ($parentPageId > 0) {
$parentPageData = DBUtil::selectObjectByID('content_page', $parentPageId);
$parentLevel = $parentPageData['level'];
} else {
$parentPageData = null;
$parentLevel = -1;
}
// Fetch largest left/right value left of this page's new position
$sql = "\n SELECT MAX({$pageColumn['setRight']})\n FROM {$pageTable}\n WHERE {$pageColumn['parentPageId']} = {$parentPageId}\n AND {$pageColumn['position']} < {$position}\n AND {$pageColumn['id']} != {$pageId}";
$maxLeftOfthis = DBUtil::selectScalar($sql);
if (empty($maxLeftOfthis)) {
$maxLeftOfthis = -1;
}
if ($parentPageData != null && $parentPageData['setLeft'] > $maxLeftOfthis) {
$maxLeftOfthis = $parentPageData['setLeft'];
}
$diff = $pageData['setRight'] - $pageData['setLeft'] + 1;
$sql = "\n UPDATE {$pageTable} SET\n {$pageColumn['setRight']} = {$pageColumn['setRight']}+{$diff}\n WHERE {$pageColumn['setRight']} > {$maxLeftOfthis} AND {$pageColumn['id']} != {$pageId}";
DBUtil::executeSQL($sql);
$sql = "\n UPDATE {$pageTable} SET\n {$pageColumn['setLeft']} = {$pageColumn['setLeft']}+{$diff}\n WHERE {$pageColumn['setLeft']} > {$maxLeftOfthis} AND {$pageColumn['id']} != {$pageId}";
DBUtil::executeSQL($sql);
// *** Update level/left/right values for this page and all pages below
$levelDiff = $pageData['level'] - ($parentLevel + 1);
$diff2 = $pageData['setLeft'] - $maxLeftOfthis - 1;
//echo "diff2=$diff2. ";
$sql = "\n UPDATE {$pageTable} SET\n {$pageColumn['setLeft']} = {$pageColumn['setLeft']}-{$diff2},\n {$pageColumn['setRight']} = {$pageColumn['setRight']}-{$diff2},\n {$pageColumn['level']} = {$pageColumn['level']}-{$levelDiff}\n WHERE {$pageData['setLeft']} <= {$pageColumn['setLeft']} AND {$pageColumn['setRight']} <= {$pageData['setRight']}";
DBUtil::executeSQL($sql);
// Update this page
$newPageData = array('id' => $pageId, 'position' => $position, 'parentPageId' => $parentPageId, 'level' => $parentPageData == null ? 0 : $parentPageData['level'] + 1);
DBUtil::updateObject($newPageData, 'content_page');
return true;
}