扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
$res=mysql_query("select
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名注册、网页空间、营销软件、网站建设、集宁网站维护、网站推广。
*
from
keyword");//查找所有关键词
while($row
=
mysql_fetch_array($rec)){//一次判断,文章中有没有出现该关键词
$str
=
$row['name'];
$rec
=
mysql_query("select
*
from
文章表
where
$title
like
'%$str%'
or
$content
like
'%$str%'");//模糊查询文章标题和内容中出现了的该关键词的数据
$num
=
mysql_num_rows($rec);//文章标题和内容中出现了的该关键词的文章条数
if($num){
echo
$str;
}
}
提交的时候记得把默认的值去掉 才能判断是否有值..
//这个是把三个搜索关键词作为独立的因子搜索
function search(){
if(isset($_POST['id']) intval($_POST['id'])0){
$sql="select * from tbl where id=".intval($_POST['id'])." ";
}
if(isset($_POST['name'])){
$sql.="union select * from tbl where name=".$_POST['name']." ";
}
if(isset($_POST['content'])){
$sql.="union select * from tbl where content like '%".$_POST['content']."%' ";
}
$s = M('search');
$result=$s-query($sql);
}
}
//以下是把三个搜索当作条件进行搜索 有筛选的味道
function search(){
$where="1=1";
if(isset($_POST['content'])){
$where.=" and content like '%$_POST[content]%'";
}
if(isset($_POST['content'])){
$where.=" and name = '$_POST[name ]'";
}
if(isset($_POST['id']) intval($_POST['id'])0){
$where.=" and id= '$_POST[id]'";
}
if($where != '1=1'){
$sql="select * from tbl $where";
}else{
throw new Exception('没有输入搜索词');
}
$s = M('search');
$result=$s-query($sql);
}
}
?php
require("conn_inc.php");//调用数据库连接文件,你的不一定是这个名字。
$asql='SELECT * FROM `total` where `ID`=1 ORDER BY `OD` ASC' ;
//上面SQL语句中,关键是最后的排序指令“ ORDER BY `OD` ASC'”,这个决定显示时的顺序。
$a2=mysql_query($asql,$myconn)or die("对不起,读入数据时出错了!". mysql_error());
while($row2=mysql_fetch_array($a2))//通过循环读取数据内容
{
echo($row2["NAME"]."——".$row2["PRICE"]."br") ;
}
?
输出来的结果如下:
T——50
S——20
D——100
P——60
L——230
你把上面
echo($row2["NAME"]."——".$row2["PRICE"]."br") ;
中的“——”改成空格,就是你要的结果了。
PHP要实现关键字查搜索,需要用到like关键字来组合查询条件
like具体实现方法如下:
例一:
1 $userForm=M('user');
1 $where['name']=array('like','phpernote%');
2 $userForm-where($where)-select();
这里的like查询即为:name like 'phpernote%'
例二:
1$where['name']=array('like',array('%phpernote%','%.com'),'OR');
这里的like查询即为:name like '%phpernote%' or name like '%.com'
例三:
1$where['name']=array(array('like','%a%'),array('like','%b%'),array('like','%c%'),'phpernote','or');
这里的like查询即为:(`name` LIKE '%a%') OR (`name` LIKE '%b%') OR (`name` LIKE '%c%') OR (`name` = 'phpernote')
例四:
1$where['_string']='(name like "%phpernote%") OR (title like "%phpernote")'
这里的like查询即为:name like '%phpernote%' or title like '%phpernote'
?php
/**
* 数据库 address
* id name
* 1 威州
* 2 张家港
* 3 宁夏回族自治区
*/
$str = "我今天想知道威州的天气。";
$charset = "GBK";
include("mysql.php"); //载入基本配置
function checkindb($string) {
$sql = "select * from address where name = '$string'";
$q = mysql_query($sql);
$r = mysql_fetch_array($q);
if ($r) {
return $string;
} else {
return false;
}
}
// 取出数据库内字符最短的地名
$sql = "SELECT CHARACTER_LENGTH(name) as a FROM `address` order by a limit 1";
$q = mysql_query($sql);
$r = mysql_fetch_array($q);
$d = $r[0];
// 取出数据库内字符最长的地名
$sql = "SELECT CHARACTER_LENGTH(name) as a FROM `address` order by a desc limit 1";
$q = mysql_query($sql);
$r = mysql_fetch_array($q);
$l = $r[0];
$arr = array();
$strlen = mb_strlen($str, $charset);
// 分割要查询的字符串
for($n = $d;$n = $l ;$n++) {
for($i = 0;$i = $strlen - $n;$i++) {
$t = mb_substr($str, $i, $n, $charset);
if (checkindb($t)) {
array_push($arr, $t);
}
}
}
print_r($arr);
?
这样应该可以,没测试!另外,安全部分要考虑下。
先遍历目录文件,把文件名保存到数据,然后使用函数检索文件名是否包含关键词即可。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流