本文整理匯總了PHP中sql::factory方法的典型用法代碼示例。如果您正苦於以下問題:PHP sql::factory方法的具體用法?PHP sql::factory怎麽用?PHP sql::factory使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類sql
的用法示例。
在下文中一共展示了sql::factory方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: registerUser
public static function registerUser()
{
$sql = sql::factory();
$sql->setTable('community_user');
$sql->getPosts(['username' => 'string', 'password' => 'string', 'email' => 'string']);
$validator = new validator();
$email = $sql->getPost('email');
$username = $sql->getPost('username');
$password = $sql->getPost('password');
$validUsername = $validator->costum($username, function () {
preg_match('/\\w{4,}/', $username, $match);
return $match[0] == $username;
});
if (!$validUsername) {
return 'Username darf nur aus Buchstaben Zahlen und Unterstrich bestehen und muss mindestens 4 Zeichen lang sein.';
}
if ($sql->num('SELECT id FROM ' . sql::table('community_user') . ' WHERE `username`= "' . $sql->escape($username) . '"')) {
return 'Benutzername schon vorhanden';
}
if (!$validator->email($email)) {
return 'Bitte geben Sie eine E-Mail Adresse an';
}
$salt = userLogin::generateSalt();
$sql->addDatePost('registerdate', 'now');
$sql->addPost('salt', $salt);
extension::get('COMMUNITY_USER_REGISTER', $sql);
$password = userLogin::hash($password, $salt);
$sql->addPost('password', $password);
$sql->save();
//Mail send
return true;
}
示例2: installSlots
public function installSlots($update = false)
{
$slots = sql::factory();
$slots->setTable('slots');
$modul = sql::factory();
$modul->setTable('module');
foreach ($this->get('slots', []) as $name => $slot) {
$slotExists = $slots->num('SELECT id FROM ' . sql::table('slots') . ' WHERE `name` = "' . $name . '" AND `template` = "' . $this->name . '"');
if (!$update && $slotExists) {
continue;
}
$modul->addPost('name', $name);
$modul->addPost('input', $slot['input']);
$modul->addPost('output', $slot['output']);
if (!$slotExists) {
$modul->save();
$modul_id = $modul->insertId();
} else {
$modul->setWhere('name="' . $name . '"');
$modul->update();
$modul->result('SELECT id FROM ' . sql::table('module') . ' WHERE name = "' . $name . '"');
$modul_id = $modul->get('id');
}
$slots->addPost('name', $name);
$slots->addPost('description', $slot['description']);
$slots->addPost('template', $this->name);
$slots->addPost('modul', $modul_id);
if (!$slotExists) {
$slots->save();
} else {
$slots->setWhere('name="' . $name . '" AND template="' . $this->name . '"');
$slots->update();
}
}
}
示例3: __construct
public function __construct($id)
{
$sql = sql::factory();
$sql->query('SELECT * FROM ' . sql::table('user') . ' WHERE id=' . $id)->result();
$this->entrys = $sql->result;
$this->entrys['perms'] = explode('|', $this->get('perms'));
}
示例4: getByStructureId
public static function getByStructureId($id)
{
$return = [];
$classname = __CLASS__;
$sql = sql::factory();
$sql->query('
SELECT
a.*, m.output
FROM
' . sql::table('structure_area') . ' AS a
LEFT JOIN
' . sql::table('module') . ' AS m
ON
m.id = a.modul
WHERE
a.structure_id=' . $id . '
AND
a.online = 1
ORDER BY
a.sort')->result();
while ($sql->isNext()) {
$sql2 = clone $sql;
$return[] = new $classname($sql2);
$sql->next();
}
return $return;
}
示例5: loginPost
protected static function loginPost()
{
$email = type::post('email', 'string');
$password = type::post('password', 'string');
// Formular ganz abgesendet?
if (is_null($email) || is_null($password) || $email == '' || $password == '') {
echo message::info(lang::get('login_form_notfull'), true);
return;
}
$sql = sql::factory();
$sql->query('SELECT password, id FROM ' . sql::table('user') . ' WHERE `email` = "' . $sql->escape($email) . '"');
// Username mit E-Mail vorhanden?
if (!$sql->num()) {
echo message::danger(sprintf(lang::get('login_no_user'), $email), true);
return;
}
$sql->result();
// Password nicht gleich?
if (!self::checkPassword($password, $sql->get('password'))) {
echo message::danger(lang::get('login_pwd_false'), true);
return;
}
self::loginSession();
self::$userID = $sql->get('id');
$_SESSION['login'] = $sql->get('id') . '||' . self::hash($password);
}
示例6: delete
public static function delete($id)
{
$sql = sql::factory();
$sql->query('SELECT `structure_id`, `sort` FROM ' . sql::table('structure_area') . ' WHERE id=' . $id)->result();
$delete = sql::factory();
$delete->setTable('structure_area');
$delete->setWhere('id=' . $id);
$delete->delete();
self::saveSortUp($sql->get('structure_id'), $sql->get('sort'));
return $sql->get('structure_id');
}
示例7: getMediaByExtension
public static function getMediaByExtension($extension)
{
$returnArray = [];
$class = __CLASS__;
$sql = sql::factory();
$sql->result('SELECT * FROM ' . sql::table('media') . ' WHERE filename LIKE "%.' . $extension . '"');
while ($sql->isNext()) {
$returnArray[] = new $class($sql);
$sql->next();
}
return $returnArray;
}
示例8: saveBlock
public static function saveBlock()
{
$id = type::post('id', 'int');
$sql = sql::factory();
$sql->setTable('blocks');
foreach (pageArea::$types as $class) {
$class = new $class();
$sql = $class->addSaveValues($sql);
}
$sql->setWhere('id=' . $id);
$sql->update();
}
示例9: getAll
public static function getAll()
{
if (!count(self::$all)) {
$sql = sql::factory();
$sql->query('SELECT name FROM ' . sql::table('addons') . ' WHERE `install` = 1 AND `active` = 1')->result();
while ($sql->isNext()) {
self::$all[] = $sql->get('name');
$sql->next();
}
}
return self::$all;
}
示例10: moduleList
public static function moduleList($active = false)
{
if (empty(self::$modulList)) {
$sql = sql::factory();
$sql->result('SELECT id, name FROM ' . sql::table('module') . ' ORDER BY `sort`');
while ($sql->isNext()) {
$selected = $active && $active == $sql->get('id') ? 'selected="selected"' : '';
self::$modulList[] = '<option value="' . $sql->get('id') . '" ' . $selected . '>' . $sql->get('name') . '</option>';
$sql->next();
}
}
return implode(PHP_EOL, self::$modulList);
}
示例11: getOptions
protected function getOptions()
{
$return = [];
if (empty($this->value)) {
return '';
}
$sql = sql::factory();
$sql->result('SELECT * FROM ' . sql::table('media') . ' WHERE id IN (' . implode(',', (array) $this->value) . ') ORDER BY FIND_IN_SET(id, "' . implode(',', (array) $this->value) . '")');
while ($sql->isNext()) {
$return[] = '<option value="' . $sql->get('id') . '">' . $sql->get('filename') . '</option>';
$sql->next();
}
return implode(PHP_EOL, $return);
}
示例12: getMetaInfos
public static function getMetaInfos($form, $type)
{
$sql = sql::factory();
$sql->query('SELECT * FROM ' . sql::table('metainfos') . ' WHERE `type` = "' . $type . '" ORDER BY `sort`')->result();
while ($sql->isNext()) {
$prefix = substr($type, 0, 3) . '_';
$attributes = $sql->getRow();
$attributes['name'] = $prefix . $attributes['name'];
$element = self::getElement($attributes, $form->get($prefix . $sql->get('name')));
$form->addElement($prefix . $sql->get('name'), $element);
$sql->next();
}
return $form;
}
示例13: getParentsName
public static function getParentsName($id)
{
$sql = sql::factory();
$sql->query('SELECT name, id, seo_costum_url, parent_id FROM ' . sql::table('structure') . ' WHERE id = ' . $id)->result();
if ($sql->get('seo_costum_url')) {
$name = $sql->get('seo_costum_url');
$name = str_replace('.html', '', $name);
} else {
$name = self::makeSEOName($sql->get('name'), false);
}
if ($sql->get('parent_id')) {
$name = self::getParentsName($sql->get('parent_id')) . '/' . $name;
}
return $name;
}
示例14: getCategoryById
public static function getCategoryById($parentId, $offlinePages = false)
{
$extraWhere = '';
if (!$offlinePages) {
$extraWhere = ' AND online = 1';
}
$class = __CLASS__;
$sql = sql::factory();
$return = [];
$sql->query('SELECT * FROM ' . sql::table('structure') . ' WHERE parent_id = ' . $parentId . $extraWhere . ' ORDER BY sort')->result();
while ($sql->isNext()) {
$sql2 = clone $sql;
$return[] = new $class($sql2);
$sql->next();
}
return $return;
}
示例15: setArticles
public function setArticles($offlines)
{
if ($offlines) {
$where = '';
} else {
$where = ' WHERE online = 1';
}
$sql = sql::factory();
$sql->query('SELECT * FROM ' . sql::table('structure') . $where . ' ORDER BY `sort`')->result();
while ($sql->isNext()) {
$prio = $sql->get('id') == dyn::get('start_page') ? 1 : 0.8;
$updatedAt = new DateTime($sql->get('updatedAt'));
$freq = self::getChangeFreq($updatedAt);
self::$articles[] = ['loc' => dyn::get('hp_url') . seo_rewrite::rewriteId($sql->get('id')), 'prio' => $prio, 'freq' => $freq, 'lastmod' => $updatedAt->format('c')];
$sql->next();
}
}