Перейти к контенту
  • 0

Запрос к MySQL в терминах драйвера IPB


Gev

Вопрос

Как такой запрос к MySQL выразить в терминах драйвера IPB 2.3.6?

 

$req="SELECT

D.*, C.grp

FROM (SELECT author_id as id, count(*) as cnt FROM $sql_pref" . "posts

WHERE pid IN ( $pid_string )

GROUP BY id ) D

LEFT JOIN

( SELECT id,mgroup as grp

FROM $sql_pref" . "members

) C ON D.id = C.id ;

";

Изменено пользователем Gev
Ссылка на комментарий
Поделиться на других сайтах

Рекомендуемые сообщения

  • 0

Такого бездарного SELECT из SELECT давно не видел....

 

Во-первых, у вас неправильно (с точки зрения логики) составлен запрос. Во-вторых - вам точно нужно в cnt выводить количество сообщений из списка сообщений $pid_string, а не общее количество сообщений пользователя? Мне почему-то кажется, вам нужно общее количество сообщений, а вот ваш неправильный запрос делает другое. В-третьих, двойки у меня нет, так что вот запрос для тройки:

 

	$this->DB->build( array( 
		'select'   => 'p.author_id, m.members_display_name, m.member_group_id, g.g_title, m.posts',
		'from'	 => array( 'p' => 'posts' ),
		'where'	=> 'p.pid in ( '.$pid_string.' )',
		'add_join' => array(
							array( 
									'select' => 'm.members_display_name, m.member_group_id, m.posts',
									'from'   => array( 'm' => 'members' ),
									'where'  => 'm.member_id=p.author_id',
									'type'   => 'left' ),
							array( 
									'select' => 'g.g_title',
									'from'   => array( 'g' => 'groups' ),
									'where'  => 'g.g_id=m.member_group_id',
									'type'   => 'left' 
								) 
							) 
)	);

Изменено пользователем Ritsuka
Ссылка на комментарий
Поделиться на других сайтах

  • 0

Для 2.3.6 почти также:

 

$this->ipsclass->DB->simple_construct( array( 
		'select'   => 'p.author_id, m.members_display_name, m.member_group_id, g.g_title, m.posts',
		'from'	 => array( 'p' => 'posts' ),
		'where'	=> 'p.pid in ( '.$pid_string.' )',
		'add_join' => array(
							array( 
									'select' => 'm.members_display_name, m.member_group_id, m.posts',
									'from'   => array( 'm' => 'members' ),
									'where'  => 'm.member_id=p.author_id',
									'type'   => 'left' ),
							array( 
									'select' => 'g.g_title',
									'from'   => array( 'g' => 'groups' ),
									'where'  => 'g.g_id=m.member_group_id',
									'type'   => 'left' 
								) 
							) 
)	);
$this->ipsclass->DB->simple_exec();

Ссылка на комментарий
Поделиться на других сайтах

Присоединиться к обсуждению

Вы можете ответить сейчас, а зарегистрироваться позже. Если у вас уже есть аккаунт, войдите, чтобы ответить от своего имени.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить на вопрос...

×   Вы вставили отформатированный текст.   Удалить форматирование

  Допустимо не более 75 смайлов.

×   Ваша ссылка была автоматически заменена на медиа-контент.   Отображать как ссылку

×   Ваши публикации восстановлены.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

Зарузка...
×
×
  • Создать...

Важная информация

Находясь на нашем сайте, вы соглашаетесь на использование файлов cookie, а также с нашим положением о конфиденциальности Политика конфиденциальности и пользовательским соглашением Условия использования.