Ir para conteúdo

Recommended Posts

Olá pessoal, 

 

Primeiramente agradecer a todos a colaboração, e meu primeiro post gostaria de dizer que todos obrigado pela hospitalidade e pretendo colaborar bastante aqui! 

 

Bom, estou fazendo um CMS para fotografos e queria que a capa de cada álbum fosse a última foto postada.

 

SELECT photo_id, photo_path, photo_album, album_id, album_nome 
FROM  photos 
INNER JOIN albuns 
ON photos.photo_album = albuns.album_id 
GROUP BY albuns.album_nome
 
Eu usei essa query, porém me retorna as primeiras fotos adicionadas, tentei usar:
 
ORDER BY photos.photo_id DESC
 
Mas msm assim, não consigo que as últimas Photo_id (adicionadas) exiba nos resultados.
 
 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
3 minutos atrás, TUAN disse:

USA O ASC

Usei ASC e DESC

 

Eu tenho 3 álbuns, e o ID já está no 20

Mas msm assim ele pega os primeiros

Screenshot_20180414-223711.png

Screenshot_20180414-223501.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Alexandro Castro Boa noite, vou te mandar um modelo do que eu uso na minha galeria onde eu eu defino o asc e o desc na hora que vou publicar esta assim

<?php
	header('Access-Control-Allow-Origin: *');
	require_once('../../includes/funcoes.php');
	require_once('../../database/config.database.php');
	require_once('../../database/config.php');
	$categoria = get('categoria');
	if (ModoManutencao()) { header("Location: ../manutencao.php"); }
	$data_atual = date('Y-m-d');
	$QueryCat = DBRead('c_album','*',"WHERE id = '{$categoria}'"); if (is_array($QueryCat)) { foreach ($QueryCat as $c_album) {
		$p           = $c_album['paginacao'];
        $ordenar_por = $c_album['ordenar_por'];
        $asc_desc    = $c_album['asc_desc'];
        $background  = $c_album['background'];
        $cor_titulo  = $c_album['cor_titulo'];
        $url         = $c_album['url'];
	} }
	if ($categoria != '0') {
		$QueryNum = DBCount('album','*',"WHERE status = 1 AND id_categoria = '{$categoria}' AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc}");
	} else {
		$QueryNum = DBCount('album','*',"WHERE status = 1 AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc}");
	}
	$pag = (isset($_GET['pag']))? $_GET['pag'] : 1;
    $registros 	= $p;
    $numPaginas = ceil($QueryNum/$registros);
    $inicio = ($registros*$pag)-$registros;
	if ($categoria != '0') {
		$Query = DBRead('album','*',"WHERE status = 1 AND id_categoria = '{$categoria}' AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc} LIMIT {$inicio}, {$registros}");
	} else {
		$Query = DBRead('album','*',"WHERE status = 1 AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc} LIMIT {$inicio}, {$registros}");
	}
?>	    
<style>
	.thumbnail:hover{ border-radius: 0px !important; border: 1px transparent !important;}
    .bg:hover { opacity: 0; }
</style>
	<div class="row">
		<div class='list-group'>
			<?php if (is_array($Query)) { foreach ($Query as $album) { ?>
            <div class='col-sm-4 col-xs-12 col-md-3 col-lg-3'>
                <a onmouseover="bg(<?php echo $album['id']; ?>)" onmouseout="bgnormal(<?php echo $album['id']; ?>)" class="thumbnail" style="background-color:<?php echo $background; ?>; border-radius: 0px !important; position: relative !important; border: 1px transparent !important;" href="#!" onclick="AbreAlbum(<?php echo $album['id']; ?>, <?php echo $categoria; ?>, <?php echo $pag; ?>, <?php echo $pag; ?>)">
                    <img class="img-responsive" alt="<?php echo $album['titulo']; ?>" src="<?php echo ConfigPainel('base_url'); ?>/wa/thumb.php?src=<?php echo ConfigPainel('base_url'); ?>/wa/album/uploads/<?php echo $album['imagem']; ?>&w=500&h=500&q=90" />
                    <div class='legenda' onmouseover="bg(<?php echo $album['id']; ?>)" onmouseout="bgnormal(<?php echo $album['id']; ?>)" style="margin-left: 4px; width: calc(100% - 8px); height: calc(55px + 5%); left: 0px; position: absolute; text-align: center; background-color: rgba(0,0,0,0.5); z-index: 2; padding: 1px; bottom: 4px;">
                        <small class='text-muted' style="font-size: 15px; color: #FFF;"><?php echo LimitarTexto($album['titulo'],50,'...'); ?></small>
                    </div>
                    <div id="bg<?php echo $album['id']; ?>" class="bg" style="margin-left: 4px; width: calc(100% - 8px); height: calc(100% - 8px); top: 4px; left: 0px; position: absolute; text-align: center; background-color: rgba(0,0,0,0.5); transition: 0.4s; z-index: 1; padding: 1px; bottom: 4px;"></div>
                </a>
            </div>
            <?php } } ?>
        </div>
	</div>

 a minha tabela sql

 

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";

INSERT INTO `modulos` (`id`, `nome`, `url`, `icone`, `status`, `ordem`, `tabela`, `cod_head`) VALUES (3, 'Ãlbum de Fotos', 'album.php', 'fa-camera', 1, 0, 'album', 'album/album.js');

CREATE TABLE IF NOT EXISTS `album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `titulo` varchar(255) NOT NULL,
  `imagem` varchar(255) NOT NULL,
  `autor` varchar(50) NOT NULL,
  `data` date NOT NULL,
  `status` enum('1','2') NOT NULL,
  `id_categoria` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

CREATE TABLE IF NOT EXISTS `c_album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `categoria` varchar(255) NOT NULL,
  `paginacao` int(11) NOT NULL,
  `paginacao_fotos` int(11) NOT NULL,
  `background` varchar(50) NOT NULL,
  `cor_titulo` varchar(50) NOT NULL,
  `url` varchar(255) NOT NULL,
  `ordenar_por` varchar(50) NOT NULL,
  `asc_desc` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

INSERT INTO `c_album` (`id`, `categoria`, `paginacao`, `background`, `cor_titulo`, `url`, `ordenar_por`, `asc_desc`) VALUES (0, 'Todos os Itens', 10, 'rgba(0,0,0,0)', '#242424', '', 'id', 'DESC');

CREATE TABLE IF NOT EXISTS `fotos_album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `titulo` varchar(255) NOT NULL,
  `imagem` varchar(255) NOT NULL,
  `data` date NOT NULL,
  `id_album` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

   Bom espero que possa te ajudar em algo com o seu ai

Compartilhar este post


Link para o post
Compartilhar em outros sites
19 minutos atrás, TUAN disse:

@Alexandro Castro Boa noite, vou te mandar um modelo do que eu uso na minha galeria onde eu eu defino o asc e o desc na hora que vou publicar esta assim


<?php
	header('Access-Control-Allow-Origin: *');
	require_once('../../includes/funcoes.php');
	require_once('../../database/config.database.php');
	require_once('../../database/config.php');
	$categoria = get('categoria');
	if (ModoManutencao()) { header("Location: ../manutencao.php"); }
	$data_atual = date('Y-m-d');
	$QueryCat = DBRead('c_album','*',"WHERE id = '{$categoria}'"); if (is_array($QueryCat)) { foreach ($QueryCat as $c_album) {
		$p           = $c_album['paginacao'];
        $ordenar_por = $c_album['ordenar_por'];
        $asc_desc    = $c_album['asc_desc'];
        $background  = $c_album['background'];
        $cor_titulo  = $c_album['cor_titulo'];
        $url         = $c_album['url'];
	} }
	if ($categoria != '0') {
		$QueryNum = DBCount('album','*',"WHERE status = 1 AND id_categoria = '{$categoria}' AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc}");
	} else {
		$QueryNum = DBCount('album','*',"WHERE status = 1 AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc}");
	}
	$pag = (isset($_GET['pag']))? $_GET['pag'] : 1;
    $registros 	= $p;
    $numPaginas = ceil($QueryNum/$registros);
    $inicio = ($registros*$pag)-$registros;
	if ($categoria != '0') {
		$Query = DBRead('album','*',"WHERE status = 1 AND id_categoria = '{$categoria}' AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc} LIMIT {$inicio}, {$registros}");
	} else {
		$Query = DBRead('album','*',"WHERE status = 1 AND data <= '{$data_atual}' AND status = '1' ORDER BY {$ordenar_por} {$asc_desc} LIMIT {$inicio}, {$registros}");
	}
?>	    
<style>
	.thumbnail:hover{ border-radius: 0px !important; border: 1px transparent !important;}
    .bg:hover { opacity: 0; }
</style>
	<div class="row">
		<div class='list-group'>
			<?php if (is_array($Query)) { foreach ($Query as $album) { ?>
            <div class='col-sm-4 col-xs-12 col-md-3 col-lg-3'>
                <a onmouseover="bg(<?php echo $album['id']; ?>)" onmouseout="bgnormal(<?php echo $album['id']; ?>)" class="thumbnail" style="background-color:<?php echo $background; ?>; border-radius: 0px !important; position: relative !important; border: 1px transparent !important;" href="#!" onclick="AbreAlbum(<?php echo $album['id']; ?>, <?php echo $categoria; ?>, <?php echo $pag; ?>, <?php echo $pag; ?>)">
                    <img class="img-responsive" alt="<?php echo $album['titulo']; ?>" src="<?php echo ConfigPainel('base_url'); ?>/wa/thumb.php?src=<?php echo ConfigPainel('base_url'); ?>/wa/album/uploads/<?php echo $album['imagem']; ?>&w=500&h=500&q=90" />
                    <div class='legenda' onmouseover="bg(<?php echo $album['id']; ?>)" onmouseout="bgnormal(<?php echo $album['id']; ?>)" style="margin-left: 4px; width: calc(100% - 8px); height: calc(55px + 5%); left: 0px; position: absolute; text-align: center; background-color: rgba(0,0,0,0.5); z-index: 2; padding: 1px; bottom: 4px;">
                        <small class='text-muted' style="font-size: 15px; color: #FFF;"><?php echo LimitarTexto($album['titulo'],50,'...'); ?></small>
                    </div>
                    <div id="bg<?php echo $album['id']; ?>" class="bg" style="margin-left: 4px; width: calc(100% - 8px); height: calc(100% - 8px); top: 4px; left: 0px; position: absolute; text-align: center; background-color: rgba(0,0,0,0.5); transition: 0.4s; z-index: 1; padding: 1px; bottom: 4px;"></div>
                </a>
            </div>
            <?php } } ?>
        </div>
	</div>

 a minha tabela sql

 


SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";

INSERT INTO `modulos` (`id`, `nome`, `url`, `icone`, `status`, `ordem`, `tabela`, `cod_head`) VALUES (3, 'Ãlbum de Fotos', 'album.php', 'fa-camera', 1, 0, 'album', 'album/album.js');

CREATE TABLE IF NOT EXISTS `album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `titulo` varchar(255) NOT NULL,
  `imagem` varchar(255) NOT NULL,
  `autor` varchar(50) NOT NULL,
  `data` date NOT NULL,
  `status` enum('1','2') NOT NULL,
  `id_categoria` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

CREATE TABLE IF NOT EXISTS `c_album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `categoria` varchar(255) NOT NULL,
  `paginacao` int(11) NOT NULL,
  `paginacao_fotos` int(11) NOT NULL,
  `background` varchar(50) NOT NULL,
  `cor_titulo` varchar(50) NOT NULL,
  `url` varchar(255) NOT NULL,
  `ordenar_por` varchar(50) NOT NULL,
  `asc_desc` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

INSERT INTO `c_album` (`id`, `categoria`, `paginacao`, `background`, `cor_titulo`, `url`, `ordenar_por`, `asc_desc`) VALUES (0, 'Todos os Itens', 10, 'rgba(0,0,0,0)', '#242424', '', 'id', 'DESC');

CREATE TABLE IF NOT EXISTS `fotos_album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `titulo` varchar(255) NOT NULL,
  `imagem` varchar(255) NOT NULL,
  `data` date NOT NULL,
  `id_album` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=0 ;

   Bom espero que possa te ajudar em algo com o seu ai

 

Bom, me ajudou um pouco em algumas ideias no PHP, mas a ideia é apenas a query no MySQL, por isso postei aqui nessa área. Gostaria de resolver apenas com query, não com PHP.

 

Eu consigo os resultados dos últimos, se eu tirar o group by, mas vai repetir os nomes dos álbuns e não funcionaria em um foreach

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por Leonardo Geja
      Olá boa noite, estou tentando fazer roda um codigo antigo e estou conseguinte erro
       
      Fatal error: Uncaught Error: Call to undefined function mysql_connect() in C:\xampp\htdocs\administrador\seguranca.php:41 Stack trace: #0 C:\xampp\htdocs\administrador\valida_login.php(3): require_once() #1 {main} thrown in C:\xampp\htdocs\administrador\seguranca.php on line 41  
      já procurei saber oque é, e entendi que esse  " mysql_connect() " parou de existir no php atual, porem não sei substituir para outro codigo, preciso de ajuda.
      abaixo o codigo  inteiro.

       
      // ============================== $_SG['conectaServidor'] = true; // Abre uma conexão com o servidor MySQL? $_SG['abreSessao'] = true; // Inicia a sessão com um session_start()? $_SG['caseSensitive'] = false; $_SG['validaSempre'] = true; // Deseja validar o usuário e a senha a cada carregamento de página? // Evita que, ao mudar os dados do usuário no banco de dado o mesmo contiue logado. $_SG['servidor'] = 'localhost'; // Servidor MySQL $_SG['usuario'] = 'root'; // Usuário MySQL $_SG['senha'] = ''; // Senha MySQL $_SG['banco'] = 'nome'; $_SG['paginaLogin'] = 'index.php'; // Página de login $_SG['paginaErro'] = 'erro.php'; // Página de login $_SG['tabela'] = 'adm'; // Nome da tabela onde os usuários são salvos // ============================== // ====================================== // ~ Não edite a partir deste ponto ~ // ====================================== // Verifica se precisa fazer a conexão com o MySQL if ($_SG['conectaServidor'] == true) { $_SG['link'] = mysql_connect($_SG['servidor'], $_SG['usuario'], $_SG['senha']) or die("MySQL: Não foi possível conectar-se ao servidor [".$_SG['servidor']."]."); mysql_select_db($_SG['banco'], $_SG['link']) or die("MySQL: Não foi possível conectar-se ao banco de dados [".$_SG['banco']."]."); } // Verifica se precisa iniciar a sessão if ($_SG['abreSessao'] == true) { session_start(); } /** * Função que valida um usuário e senha * * @param string $usuario - O usuário a ser validado * @param string $senha - A senha a ser validada * * @return bool - Se o usuário foi validado ou não (true/false) */ function validaUsuario($usuario, $senha) { global $_SG; $cS = ($_SG['caseSensitive']) ? 'BINARY' : ''; // Usa a função addslashes para escapar as aspas $nusuario = addslashes($usuario); $nsenha = addslashes($senha); $nsenha2=hash('whirlpool', $nsenha); // Monta uma consulta SQL (query) para procurar um usuário $sql = "SELECT * FROM `".$_SG['tabela']."` WHERE `nome` = '".$nusuario."' AND `senha` = '".$nsenha2."' LIMIT 1"; $query = mysql_query($sql); $resultado = mysql_fetch_assoc($query); // Verifica se encontrou algum registro if (empty($resultado)) { // Nenhum registro foi encontrado => o usuário é inválido return false; } else { // O registro foi encontrado => o usuário é valido // Definimos dois valores na sessão com os dados do usuário $_SESSION['usuarioID'] = $resultado['id']; // Pega o valor da coluna 'id do registro encontrado no MySQL $_SESSION['usuarioNome'] = $resultado['nome']; // Pega o valor da coluna 'nome' do registro encontrado no MySQL // Verifica a opção se sempre validar o login if ($_SG['validaSempre'] == true) { // Definimos dois valores na sessão com os dados do login $_SESSION['usuarioLogin'] = $usuario; $_SESSION['usuarioSenha'] = $senha; } return true; } } /** * Função que protege uma página */ function protegePagina() { global $_SG; if (!isset($_SESSION['usuarioID']) OR !isset($_SESSION['usuarioNome'])) { // Não há usuário logado, manda pra página de login expulsaVisitante(); } else if (!isset($_SESSION['usuarioID']) OR !isset($_SESSION['usuarioNome'])) { // Há usuário logado, verifica se precisa validar o login novamente if ($_SG['validaSempre'] == true) { // Verifica se os dados salvos na sessão batem com os dados do banco de dados if (!validaUsuario($_SESSION['usuarioLogin'], $_SESSION['usuarioSenha'])) { // Os dados não batem, manda pra tela de login expulsaVisitante(); } } } } /** * Função para expulsar um visitante */ function expulsaVisitante() { global $_SG; // Remove as variáveis da sessão (caso elas existam) unset($_SESSION['usuarioID'], $_SESSION['usuarioNome'], $_SESSION['usuarioLogin'], $_SESSION['usuarioSenha']); // Manda pra tela de login header("Location: ".$_SG['paginaErro']); } function expulsaVisitante2() { global $_SG; // Remove as variáveis da sessão (caso elas existam) unset($_SESSION['usuarioID'], $_SESSION['usuarioNome'], $_SESSION['usuarioLogin'], $_SESSION['usuarioSenha'], $_SESSION['placa']); // Manda pra tela de login header("Location: index.php"); } ?> Obrigado pela atenção.
    • Por Heltinhu
      Olá galera, estou no luta aqui com um cardapio, bom vamos direto ao ponto, preciso de array onde ele consulte la no meu banco de dados os itens desse cardapio, por exemplo no meu banco de dados tenho as tabelas
      Manualmente falando consegui fazer isso
      Só que como consigo fazer isso acima, porem buscadno esses dados dinamicamente lá no meu banco de dados?
      como monto esse ARRAY
    • Por marlone
      Alguém que já tenha feito checkout transparente no pagseguro poderia me ajudar? estou completamente perdido e não acho nada eficiente na interent
    • Por dougtop
      Bom tarde,
       
      Criei um banco no MySql para servir a um site Joomla. Quando criei o usuário para o banco no cPanel, ele me perguntou quais permissões eu daria e marquei tudo.
      Fiz a instalação do Joomla normalmente e deu tudo certo, mas agora, eu gostaria de saber quais permissões eu retiro para que eu tenha a melhor configuração de segurança sem impedir as ações que o sistema Joomla necessita no dia-a-dia (criação de artigo, instalação e atualização de plugins, módulos e do próprio Joomla, backup de rotina etc)?
       
      As restrições são essas:
       
      ALTER ALTER ROUTINE CREATE CREATE ROUTINE CREATE TEMPORARY TABLES CREATE VIEW DELETE DROP EVENT EXECUTE INDEX INSERT LOCK TABLES REFERENCES SELECT SHOW VIEW TRIGGER UPDATE  
      Abraços, Doug.
       
    • Por kaiquemix
      Ola amigos tudo bem? <br />
      Estou com um pequeno problema onde se no formulário eu digitar somente uma aspa ' ele não adiciona no banco de dados. Alguém poderia me dizer o porque e como eu poderia solucionar isso?
      OBs: apenas com uma aspa, se eu fechar ela com outra aspa ou colocar outro tipo de simbolo envia.
       
      Obs2: não aparece nenhum tipo de erro, ele realiza o procedimento de envio mas não insere no banco de dados.
          <?php     require_once("../config.php");     $nome = $_POST['nome'];     $tipo = $_POST['tipo'];     $data = $_POST['data'];         /*Inserar na tabela */         $query_evento = "INSERT INTO evento (nome, tipo, data) VALUES ('".$nome."', '".$tipo."', '".$data."')";         $inserir_evento = mysql_query($query_evento);          ?>  
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.