Inhaltsverzeichnis
回复讨论(解决方案)
Heim Backend-Entwicklung PHP-Tutorial sql出来的集合如何变换成想要的字符串 100分!

sql出来的集合如何变换成想要的字符串 100分!

Jun 23, 2016 pm 01:39 PM

query('SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE "%我爱你%"')

想把上面这句query出来的id 组成一个字符串,不知怎么弄呢
比如 输出了五个id值,分别是 1,2,3,4,5
现在我想把这五个值通过变换,搞成这样的字符串
(1,2,3,4,5)
不知怎么弄呢

我想用下面的方法试图做一下,但是不行呢
$result=query('SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE "%我爱你%"');
$foodsPic=array();
while($row=mysql_fetch_array($result)){
    $foodsPic[]=$row;
}
 
print_r($foodsPic);
上面这个方法不仅把id都弄进去了,把别的没用的也一鼓脑弄进去了,我只想要id的集合,并且通过处理,把这几个id搞成字符串的形式,即(1,2,3,4,5)
不知如何改进呢,


回复讨论(解决方案)

$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";$result=mysqli_query($link,$SQ);$idStr='';if(mysqli_num_rows($result)){    $data=mysqli_fetch_all($result,MYSQL_ASSOC);    foreach($data as $value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";$result=mysqli_query($link,$SQ);$idStr='';if(mysqli_num_rows($result)){    $data=mysqli_fetch_all($result,MYSQL_ASSOC);    foreach($data as $value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


写了一下还是不行,但我感觉你这个思路是正确的,只是我不会利我其中的一个数据库操作类
比如你在其中用的一个函数是 mysqli_fetch_all
我查了一下资料好象这个函数被取缔了.
另外我的系统中有一个数据库函数操作类,帖上来
<?phpdefine('InEmpireCMSDbSql',TRUE);class mysqlquery{	var $dblink;	var $sql;//sql语句执行结果	var $query;//sql语句	var $num;//返回记录数	var $r;//返回数组	var $id;//返回数据库id号	//执行mysql_query()语句	function query($query){		global $ecms_config;		$this->sql=mysql_query($query,return_dblink($query)) or die($ecms_config['db']['showerror']==1?mysql_error().'<br>'.str_replace($GLOBALS['dbtbpre'],'***_',$query):'DbError');		return $this->sql;	}	//执行mysql_query()语句2	function query1($query){		$this->sql=mysql_query($query,return_dblink($query));		return $this->sql;	}	//执行mysql_query()语句(选择数据库USE)	function usequery($query){		global $ecms_config;		$this->sql=mysql_query($query,$GLOBALS['link']) or die($ecms_config['db']['showerror']==1?mysql_error().'<br>'.str_replace($GLOBALS['dbtbpre'],'***_',$query):'DbError');		if($GLOBALS['linkrd'])		{			mysql_query($query,$GLOBALS['linkrd']);		}		return $this->sql;	}	//执行mysql_query()语句(操作数据库)	function updatesql($query){		global $ecms_config;		$this->sql=mysql_query($query,return_dblink($query)) or die($ecms_config['db']['showerror']==1?mysql_error().'<br>'.str_replace($GLOBALS['dbtbpre'],'***_',$query):'DbError');		return $this->sql;	}	//执行mysql_fetch_array()	function fetch($sql)//此方法的参数是$sql就是sql语句执行结果	{		$this->r=mysql_fetch_array($sql);		return $this->r;	}	//执行fetchone(mysql_fetch_array())	//此方法与fetch()的区别是:1、此方法的参数是$query就是sql语句 	//2、此方法用于while(),for()数据库指针不会自动下移,而fetch()可以自动下移。	function fetch1($query)	{		$this->sql=$this->query($query);		$this->r=mysql_fetch_array($this->sql);		return $this->r;	}	//执行mysql_num_rows()	function num($query)//此类的参数是$query就是sql语句	{		$this->sql=$this->query($query);		$this->num=mysql_num_rows($this->sql);		return $this->num;	}	//执行numone(mysql_num_rows())	//此方法与num()的区别是:1、此方法的参数是$sql就是sql语句的执行结果。	function num1($sql)	{		$this->num=mysql_num_rows($sql);		return $this->num;	}	//执行numone(mysql_num_rows())	//统计记录数	function gettotal($query)	{		$this->r=$this->fetch1($query);		return $this->r['total'];	}	//执行free(mysql_result_free())	//此方法的参数是$sql就是sql语句的执行结果。只有在用到mysql_fetch_array的情况下用	function free($sql)	{		mysql_free_result($sql);	}	//执行seek(mysql_data_seek())	//此方法的参数是$sql就是sql语句的执行结果,$pit为执行指针的偏移数	function seek($sql,$pit)	{		mysql_data_seek($sql,$pit);	}	//执行id(mysql_insert_id())	function lastid()//取得最后一次执行mysql数据库id号	{		$this->id=mysql_insert_id($GLOBALS['link']);		if($this->id<0)		{			$this->id=$this->gettotal('SELECT last_insert_id() as total');		}		return $this->id;	}	//返回影响数量(mysql_affected_rows())	function affectnum()//取得操作数据表后受影响的记录数	{		return mysql_affected_rows($GLOBALS['link']);	}}?>
Nach dem Login kopieren

能不能改用这里的方法呢,比如假如
先实例化这个类
$empire=news mysqlquery();
然后用$empire->的方法怎么改写上面的呢,

$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";$result=mysqli_query($link,$SQ);$idStr='';if(mysqli_num_rows($result)){    $data=mysqli_fetch_all($result,MYSQL_ASSOC);    foreach($data as $value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


<?php$sqld=$empire->query('SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE "%现货促销产品%"');//查询副表下的infotags字段$idStr='';if($empire->num($sqld)){    $data=$empire->fetch($sqld);    foreach($data as $key=>$value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}?>
Nach dem Login kopieren

我改了一下,但是没有成功,不知哪错了

$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";$result=mysqli_query($link,$SQ);$idStr='';if(mysqli_num_rows($result)){    $data=mysqli_fetch_all($result,MYSQL_ASSOC);    foreach($data as $value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


我这么写,出来结果了,但是全是乱七八糟的一些数字连在一起了
$sqld=$empire->query('SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE "%我爱你%"');//查询副表下的infotags字段
$idjh=array();
while($bqrd=$empire->fetch($sqld)){
if($bqrd[id])
$idStr.=$bqrd[id];
//$idStr=rtrim($idStr,',');
echo $idStr;

//代码误导你了 修改一下  $idStr.=$bqrd[id].',';}$idStr=rtrim($idStr,',')
Nach dem Login kopieren

另外 mysqli_fetch_all 是 PHP 的mysql数据库驱动 并没有给淘汰,只是服务器需要打开这个支持而已.有的服务器环境可能没有支持比如 sea...一般自己编译的服务器都可以轻松得到这个支持

另外 mysqli_fetch_all 是 PHP 的mysql数据库驱动 并没有给淘汰,只是服务器需要打开这个支持而已.有的服务器环境可能没有支持比如 sea...一般自己编译的服务器都可以轻松得到这个支持



这段代码改成while不用foreach的形式可以吗,并且如何改呢
$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";
$result=mysqli_query($link,$SQ);
$idStr='';
if(mysqli_num_rows($result)){
$data=mysqli_fetch_all($result,MYSQL_ASSOC);
foreach($data as $value){
if(isset($value['id']))
$idStr.=$value['id'];
}

$idStr=rtrim($idStr,',');
echo $idStr;
}

$SQ="SELECT infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%'";$result=mysqli_query($link,$SQ);$idStr='';if(mysqli_num_rows($result)){    $data=mysqli_fetch_all($result,MYSQL_ASSOC);    foreach($data as $value){        if(isset($value['id']))            $idStr.=$value['id'];    }        $idStr=rtrim($idStr,',');    echo $idStr;}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren



你这个能改成while形式吗,改完后就可以加分了

//hava a try   SELECT GROUP_CONCAT(infotags SEPARATOR ",") as infotags,id FROM hd_ecms_shop_data_1 WHERE hd_ecms_shop_data_1.infotags LIKE '%我爱你%' GROUP BY infotags
Nach dem Login kopieren

可以查询出来id的数组再用implode来处理啊,为啥非要用sql查询来处理?

可以查询出来id的数组再用implode来处理啊,为啥非要用sql查询来处理?


怎么写,无码无真相

//骚年,这是基本功的问题啊while($row=mysql_fetch_array($result)){    $id[]=$row['id'];}echo join(",",$id);
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

//骚年,这是基本功的问题啊while($row=mysql_fetch_array($result)){    $id[]=$row['id'];}echo join(",",$id);
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


上仙,再请教一下
为啥
echo $row[id];//打印不出值,也不报错
//echo join(",",$id);//能打印出值来

//骚年,这是基本功的问题啊while($row=mysql_fetch_array($result)){    $id[]=$row['id'];}echo join(",",$id);
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


上仙我搞错了,思维完全混乱造成的,
Array ( [0] => 9 [1] => 38 [2] => 39 [3] => 40 [4] => 36 [5] => 37 )

//骚年,这是基本功的问题啊while($row=mysql_fetch_array($result)){    $id[]=$row['id'];}echo join(",",$id);
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


上仙的方法不错,加分,希望今后再接再历,不要辜负我们对你的期望!钦此!

//骚年,这是基本功的问题啊while($row=mysql_fetch_array($result)){    $id[]=$row['id'];}echo join(",",$id);
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren


嗯,上仙的方法不错,加分了,上仙!
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Erklären Sie JSON Web Tokens (JWT) und ihren Anwendungsfall in PHP -APIs. Erklären Sie JSON Web Tokens (JWT) und ihren Anwendungsfall in PHP -APIs. Apr 05, 2025 am 12:04 AM

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Erklären Sie das Konzept der späten statischen Bindung in PHP. Erklären Sie das Konzept der späten statischen Bindung in PHP. Mar 21, 2025 pm 01:33 PM

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

Rahmensicherheitsmerkmale: Schutz vor Schwachstellen. Rahmensicherheitsmerkmale: Schutz vor Schwachstellen. Mar 28, 2025 pm 05:11 PM

In Artikel werden wichtige Sicherheitsfunktionen in Frameworks erörtert, um vor Schwachstellen zu schützen, einschließlich Eingabevalidierung, Authentifizierung und regelmäßigen Aktualisierungen.

Anpassung/Erweiterung von Frameworks: So fügen Sie benutzerdefinierte Funktionen hinzu. Anpassung/Erweiterung von Frameworks: So fügen Sie benutzerdefinierte Funktionen hinzu. Mar 28, 2025 pm 05:12 PM

In dem Artikel werden Frameworks hinzugefügt, das sich auf das Verständnis der Architektur, das Identifizieren von Erweiterungspunkten und Best Practices für die Integration und Debuggierung hinzufügen.

Wie sende ich eine Postanforderung mit JSON -Daten mithilfe der Curl -Bibliothek von PHP? Wie sende ich eine Postanforderung mit JSON -Daten mithilfe der Curl -Bibliothek von PHP? Apr 01, 2025 pm 03:12 PM

Senden von JSON -Daten mithilfe der Curl -Bibliothek von PHP in der PHP -Entwicklung müssen häufig mit externen APIs interagieren. Eine der gängigen Möglichkeiten besteht darin, die Curl Library zu verwenden, um Post � ...

Beschreiben Sie die soliden Prinzipien und wie sie sich für die PHP -Entwicklung anwenden. Beschreiben Sie die soliden Prinzipien und wie sie sich für die PHP -Entwicklung anwenden. Apr 03, 2025 am 12:04 AM

Die Anwendung des soliden Prinzips in der PHP -Entwicklung umfasst: 1. Prinzip der Einzelverantwortung (SRP): Jede Klasse ist nur für eine Funktion verantwortlich. 2. Open and Close Principle (OCP): Änderungen werden eher durch Erweiterung als durch Modifikation erreicht. 3.. Lischs Substitutionsprinzip (LSP): Unterklassen können Basisklassen ersetzen, ohne die Programmgenauigkeit zu beeinträchtigen. 4. Schnittstellen-Isolationsprinzip (ISP): Verwenden Sie feinkörnige Schnittstellen, um Abhängigkeiten und nicht verwendete Methoden zu vermeiden. 5. Abhängigkeitsinversionsprinzip (DIP): Hoch- und niedrige Module beruhen auf der Abstraktion und werden durch Abhängigkeitsinjektion implementiert.

Wie funktioniert die Session -Entführung und wie können Sie es in PHP mildern? Wie funktioniert die Session -Entführung und wie können Sie es in PHP mildern? Apr 06, 2025 am 12:02 AM

Die Hijacking der Sitzung kann in den folgenden Schritten erreicht werden: 1. Erhalten Sie die Sitzungs -ID, 2. Verwenden Sie die Sitzungs -ID, 3. Halten Sie die Sitzung aktiv. Zu den Methoden zur Verhinderung der Sitzung der Sitzung in PHP gehören: 1. Verwenden Sie die Funktion Session_regenerate_id (), um die Sitzungs -ID zu regenerieren. 2. Store -Sitzungsdaten über die Datenbank, 3. Stellen Sie sicher, dass alle Sitzungsdaten über HTTPS übertragen werden.

See all articles