重複行を除いて表示したい場合は、select distinctを使用する
SELECT DISTINCT [, 列名2 ...] FROM [WHERE条件式など]
※※ は必須、[]はオプション
セッションや共用SSLの問題を考えずに、普通にリンクを貼るのであれば、Zencartのデフォルトで設定されているURL(http://domain_name.com/index.php?main_page=contact_us など)をそのままテンプレート内に張り付けることで動作しますが、この方法でリンクを貼るとクッキーの使えないブラウザで正常にセッションが動作しなくなります。Zencartのセッションについてはこちらの記事で触れています。
セッションを維持するリンクの貼り方は状況によっていくつか考えられるので、順に説明していきたいと思います。目次
1.Zencart(filenames.php)にもともと定義されているページへのリンクの貼り方
■形式 非SSLの場合 :<a href="<?php echo zen_href_link(FILENAME_CONTACT_US, '', 'NONSSL'); ?>">お問い合わせ</a>SSLの場合 :
<a href="<?php echo zen_href_link(FILENAME_LOGIN, '', 'SSL'); ?>">ログイン</a>この場合は、「FILENAME~」となっている箇所を includes/filenames.php に定義されている名前と同じものを設定することになります。 SSLにするかどうかの設定は「SSL」または、「NONSSL」を記述します。
2.Zencart(filenames.php)にもともと定義されていないページへのリンクの貼り方
例えば、「http://domain_name.com/index.php?main_page=index&cPath=14」にリンクを張りたい場合などです。 ■形式<a href="<?php echo zen_href_link("index&cPath=14", '', 'NONSSL'); ?>">ページ名</a>この場合は、「index&cPath=14」となっている箇所を編集します。 URLで 「index.php?main_page=」 以降の箇所を赤字の箇所に指定することで動作します。 SSLにするかどうかの設定は「SSL」または、「NONSSL」を記述します。
3.オリジナルのphpプログラムの中で動かすような場合
例として、カテゴリIDを取得し、自動でカテゴリ名へリンクを設置するようなプログラムを作るとします。そのリンク箇所にセッションが正常に引き継げるように設定します。 ■形式<a href="http://domain_name/index.php?main_page=index&cPath=<?php echo $categories_id ; ?>&<?php echo zen_session_name(); ?>=<?php echo zen_session_id() ; ?>">リンク</a>Zencart内で、zen_session_nameというのは「zenid」のことです。zen_session_idというのはzenidの値のことです。 このやり方については、クッキーの設定に関わらず、URL内のzenidにてセッションを引き継ぐ方法ですが、セキュリティ面を考慮すると、もう少しスマートなやり方があるかもしれません。
この投稿へのコメント