PHP数据访问修改和多条件查询(20161030)

查询分为关键字查询和准确查询

1.没有提交的时候--查所有

2.两个输入都为空--查所有
3.第一个条件有,第二个为空--根据第一个条件查
4.第一个没有,第二个有--根据第二个条件查
5.两个都有--根据两个条件查

where name like ‘%宋%‘ and 1=1
where 1=1 and nation=‘n001‘

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<!-- 修改思路:提交到当前页面,根据传过来的数据查:-->
<body>
<br />
<form action="1028afternoonmain.php" method="post">
<div>姓名:
<input type="text" name="xm" />
<input type="submit" value="查询" />
</div>
</form>
<br />
<form action="1101morningpiliangshanchu.php" method="post">
<table width="100%" border="1" cellpadding="0" cellspacing="0">
    <tr>
        <td><input type="checkbox" onclick="quanxuan(this)" />代号</td>
        <td>姓名</td>
        <td>性别</td>
        <td>民族</td>
        <td>生日</td>
        <td>操作</td>

    </tr>

<?php
//查询规律:在用户不输入的情况下,查询的是全部数据
//先判断有没有提交值

/*简化前
$xm="";
if(!empty($_POST["xm"]))//empty();判断是否为空.加一个条件判断,防止报错
{
    $xm = $_POST["xm"];
}

//简化前
$tj = "";
if($xm == "")//如果没有值,查所有的,不加条件,或者给一个恒成立的条件。如果有值,按条件查找
{
    $tj = " 1=1 ";//不要忘记两边加空格(方便拼接sql语句)
}
else
{
    $tj = " name like ‘%{$xm}%‘ ";//不要忘记两边加空格,模糊查询用like
}
//简化后
$tj = " 1=1 ";//默认恒成立
if($xm != "")
{
    $tj = " name like ‘%{$xm}%‘ ";
}
*/
//简化后 写法一:
$xxm = "";
$tj = " 1=1 ";
if(!empty($_POST["xm"]) && $_POST["xm"] !="")//判断xm是否为空
{
    $xxm = $_POST["xm"];
    $tj = " name like ‘%{$_POST[‘xm‘]}%‘ ";    //变量里面可以加单引号
}
/*简化后 写法二:
$tj = " 1=1 ";
if(!empty($_POST["xm"]))//判断xm是否为空
{
    if($_POST["xm"] !="")//判断xm是否为空字符串
    {
        $tj = " name like ‘%{$xm}%‘ ";
    }
}*/

//造连接对象
$db = new MySQLi("localhost","root","数据库密码","1016");
//写sql语句
$sql = "select * from info where ".$tj;//(拼接sql语句,where后面的空格是为了防止拼接语句错误.单独拿出来是因为如果写成一句的话,用户如果什么都不输入,查询的值则为空,这与查询规律冲突即用户什么都不输入的情况下,查询全部数据)
//执行sql语句
$result = $db->query($sql);
//读数据,返回一个二维数组
$attr = $result->fetch_all();
//foreach遍历数组,
foreach($attr as $v)//$attr as $v取attr里面的每一个小数组
{
    echo"<tr>";    

    $sex = $v[2]?"男":"女";//数组v $v 取索引二,用三元运算符判断,前面是一个布尔型数据,true显示男,false显示女 0 false,1 true

    //根据民族代号查询民族名称    也可以使用join查询,但是一般不推荐使用,因为查询的数据量太大了

    /*$sname = "select name from nation where code = ‘{$v[3]}‘";
    $rname = $db->query($sname);
    $aname = $rname->fetch_row();*/

    $name = nationname($v[3]);
    //使关键字高亮 <mark></mark>
    /*简化后的在上面
    $xxm = "";//先把xxm变量定义在外层
    if(!empty($_POST["xm"]))//然后判断是否有提交值
    {
        $xxm = $_POST["xm"];//有传值的话就取xm
    }
    */
    //替换关键字
    $newname = str_replace($xxm,"<mark>{$xxm}</mark>",$v[1]);//查找替换,第一个参数:关键字,根据什么去找;第二个关键字,替换后的内容;第三个参数:要替换哪个字符串,即要替换的区域
    //复选的话用数组提交 sc[] ,到处理页面,遍历数组就可以了
    echo"<td><input type=‘checkbox‘ value=‘{$v[0]}‘ name=‘sc[]‘ class=‘qx‘ />{$v[0]}</td><td>{$newname}</td><td>{$sex}</td><td>{$name}</td><td>{$v[4]}</td><td><a href=‘1028afternoonshanchu.php?c={$v[0]}‘>删除</a> <a href=‘1030morningxiugai.php?c={$v[0]}‘>修改</a></td>";

    //跳转到另外一个页面并且带一个值过去的方式是get方式,因此我们要模拟一个get传值方式    ?c={$v[0]}

    //要想加入删除的功能要先让它可以点击,一种方法是按钮,另一种方法是<a>标签。样式可以随便做,比如在外面加上一个漂亮的DIV,在里面加上<a>标签。

    /*输出的两种方法
    foreach($v as $v1)
    {
        echo "<td>{$v1}</td>";
    }*/

    echo"</tr>";
}

    //给一个民族代号,返回民族名称
    function NationName($code)
    {
        //造连接对象
        $db = new  MySQLi("localhost","root","数据库密码","1016");
        //写SQL语句
        $sql = "select name from nation where code=‘{$code}‘";
        //执行SQL语句
        $result = $db->query($sql);

        $attr = $result->fetch_row();

        return $attr[0];
    }

?>

</table>
<a href="1028afternoonadd.php"><input type="button" value="添加数据" /></a>
<input type="submit" value="批量删除" onclick="return confirm(‘确定删除吗?‘)" />
</form>
<!--批量删除思路:把复选框和批量删除按钮看作是一个表单-->

<script>

function quanxuan(a)

{
    //找到下面所有的复选框
    var ck = document.getElementsByClassName("qx");
    //不是document点出来的就没有提示,如果怕出错可以在这里随便定义一个变量然后点出来然后复制过来
    //遍历所有复选框,设置选中状态
    for(var i=0;i<ck.length;i++)
    {
        if(a.checked)
        {
            /*setAttribute("checked","checked")
            设置属性(“名字”;“值”)*/
            ck[i].setAttribute("checked","checked");
        }
        else
        {
            /*removeAttribute("checked","checked")
            移除属性(“名字”;“值”)*/
            ck[i].removeAttribute("checked","");
        }
    }

}

</script>

</body>
</html>

1028afternoonmain.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>

<body>
<!--嵌入PHP代码查询数据库-->
<?php
    $code = $_GET["c"];
    //造连接对象
    $db = new MySQLi("localhost","root","789","1016");
    //写sql语句
    $sinfo = "select * from info where code=‘{$code}‘";
    //$db调用query方法,执行sql语句,返回一个结果集对象
    $rinfo = $db->query($sinfo);
    //从结果集里面读数据,返回一个数组
    $ainfo = $rinfo->fetch_row();
?>

<form action="1028afternoonxiugaichuli.php" method="post">
    <!--用post提交方式时name=""是提交的值
    为了对用户友好,即用户输入方便,将性别和民族从文本框改成下拉菜单,方便选择.代号不能随便让用户修改(避免重复),因此把它做成只读  readonly="readonly"  但是还需要提交,所以就不能使用  disabled="disabled"  或者如果主键值是自增长列或者是对用户没有意义的,则可以隐藏,即先把代号删掉,然后把type从"text"改成"hidden" 隐藏域-->
  <div><!--代号:--><input readonly="readonly" type="hidden" name="code" value="<?php echo $ainfo[0]; ?>" /></div>
    <div>姓名:<input type="text" name="name" value="<?php echo $ainfo[1]; ?>" /></div>

    <!--做成修改的思路:选中用的是属性checked,如果性别是true的话就让男的加一个属性(即如果sex为true,就输出一个checked="checked"),如果性别是false的话就让女的加一个属性-->
    <div>性别:
    <input type="radio" name="sex" value="1" <?php echo $ainfo[2]?"checked=‘checked‘":"" ?>  />男
    &nbsp;
    <input type="radio" name="sex" value="0"  <?php echo $ainfo[2]?"":"checked=‘checked‘" ?> />女
    </div>

    <div>民族:
    <select name="nation" style="width:173px; position:relative; right:8px">
        <?php
        //造连接对象
        $db = new MySQLi("localhost","root","789","1016");
        $sql = "select * from nation";
        $result = $db->query($sql);
        $attr = $result->fetch_all();

    /*单选菜单选中checked="checked"  多选菜单选中selected="selected"    思路:因为是用foreach循环,因此可以在输出前判断用户的代号($ainfo[3])是不是输出的代号($v[0])*/

        foreach($attr as $v)
        {
            if($v[0]==$ainfo[3])
            {
                echo "<option selected=‘selected‘ value=‘{$v[0]}‘>{$v[1]}</option>";
            }
            else
            {
                echo "<option value=‘{$v[0]}‘>{$v[1]}</option>";    }//<option>中间是显示用的,value值才是提交的数据
        }
        ?>

    </select>
    <!--下拉列表<select><option></option></select>-->
    </div>
    <div>生日:<input type="text" name="birthday" value="<?php echo $ainfo[4]; ?>" /></div>
    <div><input type="submit" value="修改" /></div>
    <!--提交按钮submit的value是显示的内容-->

</form>

</body>
</html>

1030morningxiugai.php

<?php
//这种页面不能直接跳转,要通过上一个页面跳转
//把提交的5个值取出
$code = $_POST["code"];
$name = $_POST["name"];
$sex = $_POST["sex"];
$nation = $_POST["nation"];
$birthday = $_POST["birthday"];
//造连接对象
$db = new MySQLi("localhost","root","数据库密码","1016");
//写sql语句 set name=‘{$name}‘ 把数据库的name修改成用户输入的name
$sql = "update info set name=‘{$name}‘,sex={$sex},nation=‘{$nation}‘,birthday=‘{$birthday}‘ where code=‘{$code}‘";
echo $sql;
$db->query($sql);

header("location:1028afternoonmain.php");

?>

1028afternoonxiugaichuli.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<!-- 思路提交到当前页面,根据传过来的数据查;几个条件几个if循环-->
<body>
<br />
<form action="1030afternoonduotiaojian.php" method="post">
<div>姓名:
<input type="text" name="xm" />
民族代号:
<input type="text" name="mz" />
<input type="submit" value="查询" />
</div>
</form>
<br />

<table width="100%" border="1" cellpadding="0" cellspacing="0">
    <tr>
        <td>代号</td>
        <td>姓名</td>
        <td>性别</td>
        <td>民族</td>
        <td>生日</td>
        <td>操作</td>

    </tr>

<?php
//查询规律:在用户不输入的情况下,查询的是全部数据
//先判断有没有提交值

/*简化前
$xm="";
if(!empty($_POST["xm"]))//empty();判断是否为空.加一个条件判断,防止报错
{
    $xm = $_POST["xm"];
}

//简化前
$tj = "";
if($xm == "")//如果没有值,查所有的,不加条件,或者给一个恒成立的条件。如果有值,按条件查找
{
    $tj = " 1=1 ";//不要忘记两边加空格(方便拼接sql语句)
}
else
{
    $tj = " name like ‘%{$xm}%‘ ";//不要忘记两边加空格,模糊查询用like
}
//简化后
$tj = " 1=1 ";//默认恒成立
if($xm != "")
{
    $tj = " name like ‘%{$xm}%‘ ";
}
*/
//简化后 写法一:
$xxm = "";
$tj = " 1=1 ";
$tj2 = " 1=1 ";
if(!empty($_POST["xm"]) && $_POST["xm"]!="")//判断xm是否为空
{
    $xxm = $_POST["xm"];
    $tj = " name like ‘%{$_POST[‘xm‘]}%‘ ";    //变量里面可以加单引号
}
/*简化后 写法二:
$tj = " 1=1 ";
if(!empty($_POST["xm"]))//判断xm是否为空
{
    if($_POST["xm"] !="")//判断xm是否为空字符串
    {
        $tj = " name like ‘%{$xm}%‘ ";
    }
}*/
//第二个条件
if(!empty($_POST["mz"]) && $_POST["mz"]!="")
{
    $mz = $_POST["mz"];
    $tj2 = " nation=‘{$mz}‘ ";
}

//造连接对象
$db = new MySQLi("localhost","root","789","1016");
//写sql语句
$sql = "select * from info where ".$tj." and ".$tj2;
//一个小的并一个大的,得出的以小的为主
//(拼接sql语句,where后面的空格是为了防止拼接语句错误.单独拿出来是因为如果写成一句的话,用户如果什么都不输入,查询的值则为空,这与查询规律冲突即用户什么都不输入的情况下,查询全部数据)
//执行sql语句
$result = $db->query($sql);
//读数据,返回一个二维数组
$attr = $result->fetch_all();
//foreach遍历数组,
foreach($attr as $v)//$attr as $v取attr里面的每一个小数组
{
    echo"<tr>";    

    $sex = $v[2]?"男":"女";//数组v $v 取索引二,用三元运算符判断,前面是一个布尔型数据,true显示男,false显示女 0 false,1 true

    //根据民族代号查询民族名称    也可以使用join查询,但是一般不推荐使用,因为查询的数据量太大了

    /*$sname = "select name from nation where code = ‘{$v[3]}‘";
    $rname = $db->query($sname);
    $aname = $rname->fetch_row();*/

    $name = nationname($v[3]);
    //使关键字高亮 <mark></mark>
    /*简化后的在上面
    $xxm = "";//先把xxm变量定义在外层
    if(!empty($_POST["xm"]))//然后判断是否有提交值
    {
        $xxm = $_POST["xm"];//有传值的话就取xm
    }
    */
    //替换关键字
    $newname = str_replace($xxm,"<mark>{$xxm}</mark>",$v[1]);//查找替换,第一个参数:关键字,根据什么去找;第二个关键字,替换后的内容;第三个参数:要替换哪个字符串,即要替换的区域

    echo"<td>{$v[0]}</td><td>{$newname}</td><td>{$sex}</td><td>{$name}</td><td>{$v[4]}</td><td><a href=‘1028afternoonshanchu.php?c={$v[0]}‘>删除</a> <a href=‘1030morningxiugai.php?c={$v[0]}‘>修改</a></td>";

    //跳转到另外一个页面并且带一个值过去的方式是get方式,因此我们要模拟一个get传值方式    ?c={$v[0]}

    //要想加入删除的功能要先让它可以点击,一种方法是按钮,另一种方法是<a>标签。样式可以随便做,比如在外面加上一个漂亮的DIV,在里面加上<a>标签。

    /*输出的两种方法
    foreach($v as $v1)
    {
        echo "<td>{$v1}</td>";
    }*/

    echo"</tr>";
}

    //给一个民族代号,返回民族名称
    function NationName($code)
    {
        //造连接对象
        $db = new  MySQLi("localhost","root","789","1016");
        //写SQL语句
        $sql = "select name from nation where code=‘{$code}‘";
        //执行SQL语句
        $result = $db->query($sql);

        $attr = $result->fetch_row();

        return $attr[0];
    }

?>

</table>
<a href="1028afternoonadd.php"><input type="button" value="添加数据" /></a>

</body>
</html>

1030afternoonduotiaojian.php

时间: 2024-10-24 18:49:06

PHP数据访问修改和多条件查询(20161030)的相关文章

ADO.NET(完整修改和查询、实体类,数据访问类)

一.完整修改和查询 在编写c#语句时需考虑到用户体验,例如在编写修改语句时,需要考虑到输入的内容在数据库中是否能够找到. 中间变量运用. 1.先查 2.执行操作 完整修改语句: bool has = false; Console.Write("请输入要修改的用户名:"); string Uname = Console.ReadLine(); //到数据库中查询输入的用户名是否存在 SqlConnection conn = new SqlConnection("server=.

大数据技术之_20_Elasticsearch学习_01_概述 + 快速入门 + Java API 操作 + 创建、删除索引 + 新建、搜索、更新删除文档 + 条件查询 + 映射操作

一 概述1.1 什么是搜索?1.2 如果用数据库做搜索会怎么样?1.3 什么是全文检索和 Lucene?1.4 什么是 Elasticsearch?1.5 Elasticsearch 的适用场景1.6 Elasticsearch 的特点1.7 Elasticsearch 的核心概念1.7.1 近实时1.7.2 Cluster(集群)1.7.3 Node(节点)1.7.4 Index(索引 --> 数据库)1.7.5 Type(类型 --> 表)1.7.6 Document(文档 -->

利用PHP访问数据库——实现分页功能与多条件查询功能

1.实现分页功能 <body><table width="100%" border="1">  <thead>    <tr>      <th>代号</th>      <th>名称</th>      <th>价格</th>    </tr>  </thead>  <tbody>      <?php 

Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询

1.搭建环境 新建JAVA项目,添加的包有: 有关Hadoop的hadoop-core-0.20.204.0.jar 有关Hbase的hbase-0.90.4.jar.hbase-0.90.4-tests.jar以及Hbase资源包中lib目录下的所有jar包 2.主要程序 Java代码 package com.wujintao.hbase.test; import java.io.IOException; import java.util.ArrayList; import java.util

8.修改 按条件查询商品 分页

修改商品的原理图 jsp页面 edit.jsp <%@ page language="java" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <HTML> <HEAD> <meta http-equiv="Content-Langua

C# 将Access中时间段条件查询的数据添加到ListView中

C# 将Access中时间段条件查询的数据添加到ListView中 一.让ListView控件显示表头的方法 在窗体中添加ListView 空间,其属性中设置:View属性设置为:Detail,Columns集合中添加表头中的文字. 二.利用代码给ListView添加Item. 首先,ListView的Item属性包括Items和SubItems.必须先实例化一个ListIteView对象.具体如下: ListViewItem listViewItem=new ListViewItem(); l

yii2数据条件查询-where专题

条件查询 $customers = Customer::find()->where($cond)->all(); $cond就是我们所谓的条件,条件的写法也根据查询数据的不同存在差异,那么如何用yii2的方式来写查询条件呢? [[简单条件]] // SQL: (type = 1) AND (status = 2). $cond = ['type' => 1, 'status' => 2]  // SQL:(id IN (1, 2, 3)) AND (status = 2) $con

Atitit.列表页面and条件查询的实现最佳实践(1)------设置查询条件and提交查询and返回json数据

1. 1.?配置条件字段@Conditional 1 1 2. 2.?配置条件字段显示类型为[email protected](displayType?=?displayType.rang,?rangStart?=?rang.start,?rangEnd?=?rang.end,op=op.range) 1 3. #----show  condition  page  list 1 4. 提交条件查询表单by dwr 1 5. @filter  ::   set filter condition 

ecshop后台根据条件查询后不填充table 返回的json数据,content为空?

做ecshop后台开发的时,根据条件查询后,利用ajax返回的content json数据内容为空,没有填充table 效果 预期效果 问题: make_json_result($smarty -> fetch('packages_list_info.htm'), '', array('filter' => $result['filter'], 'page_count' => $result['page_count'])); 问题出在 packages_list_info.htm页面里