質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

1054閲覧

php sql if文条件式

mb.tata

総合スコア1

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2020/12/08 02:02

編集2020/12/08 02:10

php

1function chkSimpleRule() 2 { 3 $result='0'; //非表示を初期値としてセットしているから 4 $userinfo = $this->backend->cipher['userinfo']; //ユーザー情報を取得 5 $role = $this->af->userinfo2role($userinfo); //権限を取得 6 if($role == 'cipheradm'){ //システム管理者か判定 7 return $result;//システム管理者の場合は「0:暗号化ルール簡易表示利用しない」を返却して終了 8 } 9 if($role == 'cipherdomain' || $role == 'cipheruser' ){ //ドメインか一般ユーザーならtrue 10 $user_account = $userinfo['account']; //ユーザー以外か判定 11 if($role == 'cipheruser'){ 12 if(preg_match('/@([^@]+)$/', $user_account, $m)){ 13 $user_account = '@' . $m[1]; //@以降のドメイン部分を取得している。 14 } 15 } 16 $user_id = '0'; 17 $sql = "SELECT tusr_id FROM tusr_user WHERE tusr_account = ?"; //ユーザーアカウントを代入 18 $sql = "SELECT tusr_id FROM tusr_user WHERE tusr_account IN (SELECT tusr_account FROM tdmn_domain WHERE tdmn_add_domain = ?)"; 19 $sth = $this->db_cipher->db->prepare($sql); 20 $user_id = $this->db_cipher->db->getOne($sql,array($user_account)); //取得したドメインがユーザ登録されてるか、ユーザ情報テーブル(tusr_user)から取得 21 if (Ethna::isError($user_id) || $user_id == '0') { //登録されていない場合は「0:暗号化ルール簡易表示利用しない」を返却して終了 22 return $result; 23 } 24 $result = $this->chkDomainSimpleRule($user_id); //取得したユーザIDで暗号化ルール簡易表示の利用有無のチェック関数呼び出す 25 return $result; 26 27 } else{ 28 return $result; 29 } 30 }

18行目の$sql = "SELECT tusr_id FROM tusr_user WHERE tusr_account IN (SELECT tusr_account FROM tdmn_domain WHERE tdmn_add_domain = ?)";を記述した際、(1回目のSQL実行)if文で条件判定(条件次第で2回目を実行)というif文を記述したいです。
17行目で登録されているか確認テーブルから取得し登録されていなかったら18行目のドメインが登録されているかチェックしたいです。
if文の何を使えばいいかおおまかな構文だけでも知りたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_waiwai

2020/12/08 02:05

しつもんはなんでしょうか。 提示のコードでどういう不具合があり、それをどうしたいということなんでしょう
mb.tata

2020/12/08 02:09 編集

18行目が17行目を上書き?しているので17行目と18行目同じ値を返したいです。 if文の追加記述をしたいです・
m.ts10806

2020/12/08 02:29

>if文の何を使えばいいか といってもif文は1つしかありません。 別々のSQL保持したいなら変数名かえればいいと思うのですが、そういうことではないのでしょうか。
m.ts10806

2020/12/08 02:30

それに利用しているフレームワークがあるのでしょうか。それとも自身で作ったものでしょうか。 構造が不明です。
guest

回答1

0

ベストアンサー

なぜ、17行目の$sqlを処理せずに18行目の$sqlですぐ上書きしているのかわかりません。
変数$sqlはあくまで文字列を代入しているだけです。

やりたいことはおそらく
①アカウントが既存のアカウントか確認し、値を返す(17行目)
②ドメイン情報を取得しているアカウントを確認(18行目)
でしょう。

現状だと②しか処理されていないので、②の処理前に①を処理し、結果を返す必要があります。

投稿2020/12/08 05:23

編集2020/12/08 05:24
FKM

総合スコア3647

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mb.tata

2020/12/08 05:25

それです! 具体的に指示できますか?
FKM

2020/12/08 05:28

17行目のSQLを放置せず処理結果を返してくださいとしか言えないです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問