java web数据库查询_Java Web开发之信息查询方式总结
本文实例讲述了Java Web开发之信息查询方式总结。分享给大家供大家参考。具体如下:
这里介绍的查询方式有:
① 根据某个特定的字段查询;
② 在多个字段中查询;
③ 根据任意字段查询;
④ 任意字段组合查询;
⑤ 多值查询。
根据某个特定的字段进行查询
用户在输入界面中输入要查询的字段的值,然后系统根据这个值进行查找。
下面的实例是根据用户名查询用户的详细信息,简单的效果图如下:
关键代码如下:
请输入要查询的姓名:
处理文件的代码如下:
StringBuffer sql=new StringBuffer();
//查询字符串
String username = request.getParameter("username");
//查询的条件
if(username==null||username.length()==0)
{
out.println("请输入查询条件!");
}
else
{
sql.append("select * from user where username like '");
sql.append(username);
sql.append("'");
}
//接下来根据上面生成的sql进行查询即可
%>
这里主要关心SQL语句即可,查询过程和显示过程参考其它主题。
上面进行的是精确的查询,可以进行模糊查询,例如可以查询用户名包含某个字的用户的信息。
只需要修改代码中的查询语句部分,修改后的代码如下:
sql.append("select * from user where username like '%");
sql.append(username);
sql.append("%'");
仅仅增加了模糊查询的通配符“%”,如果要查询以什么开头,去掉前面的通配符即可,如果查询以什么结束,去掉后面的同配符即可。
在多个字段中查询
假设有一个关于Java技术的BBS,每个记录都有标题、摘要、内容等字段,这里我们忽略其它字段,如果用户希望查看关于编码的问题,他希望不管是在标题、摘要还是内容中只要包含他输入的信息都应该能够查询出来,这时候就需要在多个字段中查询。
关键代码如下:
请输入要查询的关键字:
查询的处理代码如下:
StringBuffer sql=new StringBuffer();
//查询字符串
String condition =request.getParameter("condition");
//查询的条件
if(condition==null||condition.length()==0)
{
out.println("请输入查询条件!");
}
else
{
sql.append("select * from user where title like '%");
sql.append(condition);
sql.append("%' and summary like '%");
sql.append(condition);
sql.append("%' and detail like '%");
sql.append(condition);
sql.append("%'");
}
//接下来根据上面生成的sql进行查询即可
%>
根据任意字段查询
可以让用户选择根据什么进行查询,然后输入要查询的值,这样的查询比较复杂,但是对于用户来说最方便。
处理文件:
StringBuffer sql=new StringBuffer();
//查询字符串
String condition = request.getParameter("condition");
//查询的字段
String v = request.getParameter("v");
//查询的值
if(v.length()==0)
{
out.println("请输入查询条件!");
}
else
{
sql.append("select * from user where ");
//根据用户选择的字段进行处理
if(condition.equals("a"))
sql.append(" a like '");
else if(condition.equals("b"))
sql.append(" b like '");
else
sql.append(" c like '");
sql.append(v);
sql.append("'");
/*
如果界面中下拉列表中的条件是数据库中字段的名字,上面的代码会非常简单:
sql.append("select * from user where ");
sql.append(condition);
sql.append(" like '");
sql.append(v);
sql.append("'");
*/
}
//接下来根据上面生成的sql进行查询即可
%>
任意组合查询
把所以可以查询的字段全部列出来,每个字段对应一个输入框,用户可以根据某个字段或者某几个字段进行查询,需要根据什么查询,在相应的输入框中输入信息即可。
查询的处理文件:
StringBuffer sql=new StringBuffer();
//查询字符串
String a = request.getParameter("a");
String b = request.getParameter("b");
String c = request.getParameter("c");
String d = request.getParameter("d");
//获取用户输入的查询条件
sql.append("select * from user where");
if(a.length()!=0)
{
sql.append(" a like '");
sql.append(a);
sql.append("' and");
}
if(b.length()!=0)
{
sql.append(" b like '");
sql.append(b);
sql.append("' and");
}
if(c.length()!=0)
{
sql.append(" c like '");
sql.append(c);
sql.append("' and");
}
if(d.length()!=0)
{
sql.append(" d like '");
sql.append(d);
sql.append("' and");
}
sql.trim(sql.length-3,3);
//删除最后的4个字母(" and")
//接下来根据上面生成的sql进行查询即可
%>
多值查询
用户在单个输入框输入多个数据进行查询,可以查询某个字段同时包含多个关键字,例如查询主题中既包含“java”又包含“C++”的记录,或者一个数字区间,例如年龄在19和22之间的记录,或者一个时间范围,例如出生在1981年1月1日和1983年12月31日之间的记录。
这里只介绍按照数字区间进行查找的,其它情况的实现基本相同。
处理文件:
StringBuffer sql=new StringBuffer();
//查询字符串
String condition = request.getParameter("condition");
//获取查询条件
int index = condition.indexof(" ");
//查找空格位置,空格作为两个数字的分隔符
String min=condition.subString(1,index);
//前面的值
String max=condition.subString(index+1,condition.length-1);
//后面的值
try
{
Integer.parseInt(min);
Integer.parseInt(max);
}catch(Exception e)
{
out.println("输入的信息不合法!");
return;
}
sql.append("select * from user where age between ");
sql.append(min);
sql.append(" and ");
sql.append(max);
//构造查询字符串
//接下来根据上面生成的sql进行查询即可
%>
希望本文所述对大家的JSP程序设计有所帮助。
java web数据库查询_Java Web开发之信息查询方式总结相关推荐
- java web数据库设计_java web的新闻发布系统的数据库设计
展开全部 一个表记32313133353236313431303231363533e78988e69d8331333332643837录站点信息, website CREATE TABLE `webs ...
- JAVA实现数据库编程第三章_[数据库]使用Java实现数据库编程—03 第三章 高级查询(一)...
[数据库]使用Java实现数据库编程-03 第三章 高级查询(一) 0 2018-07-21 03:01:10 1.修改表:(1)修改表名语法: ALTER TABLE RENAME [ TO ] : ...
- JAVA设计驾驶员信息管理系统_基于jsp的大连驾驶员信息查询-JavaEE实现大连驾驶员信息查询 - java项目源码...
基于jsp+servlet+pojo+mysql实现一个javaee/javaweb的大连驾驶员信息查询, 该项目可用各类java课程设计大作业中, 大连驾驶员信息查询的系统架构分为前后台两部分, 最 ...
- java web 数据库操作_Java Web----Java Web的数据库操作(三)
Java Web的数据库操作 前面介绍了JDBC技术和JDBC API及API的使用示例,下面详细介绍JDBC在Web中的应用. 四.JDBC在Java Web中的应用 通常情况下,Web程序操作数据 ...
- java web 许令波_Java Web——Web概述
已经很久没有更新博客了,过年忙着吃喝玩乐,就怠惰了一小下下?幸好这学期新开的课程都比较有趣--Java Web和Android.至少对于我自己来说,既充满挑战,又富有趣味. --[1.Web概述]-- ...
- java web网上书店_java web简易网上书店项目系列,使用MVC模式(servlet+jstl+dbutils),开篇...
一. 针对很多java web初学者入门困难的问题,笔者利用一个小型web项目,一步一步的展示java web开发方法,每一个章节引入一些java web开发的重点知识,让同学们可以将java web ...
- java web 用户管理_Java Web(九) 用户管理系统
前面学习了一大堆,什么JSP,Servlet.jstl.el等等等,大多是一些死的东西,只要会其语法,知道怎么用就行了,所以做了一个小小的只有增删改查的小demo,为的就是熟悉这些知识.灵活运用起来. ...
- java web项目测试_java web项目怎么测试?
慕仰1329654 java web项目测试用Web的测试工具,如HtmlUnit,JWebUnit等.main()方法就可以测试,在main方法中获得connection对象将他输出就可以了.如果正 ...
- java web 监听器 例子_Java web技术应用---监听器
监听器的定义 (专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生变化时,立即采取相应的行动) 定义:Servlet规范中定义的一种特殊的类,用于监听Servlet ...
最新文章
- 高斯过程及其家族往事
- 三值网络--Trained Ternary Quantization
- 即时通讯软件设计(一)
- 配置FTP服务-要点总结
- Swoole同步/异步/阻塞/非阻塞的理解
- 神器面世:让你快速在 iOS 设备上安装 Windows、Linux 等操作系统!
- include *.h 和 declare class *; 的区别?
- Python爬虫实战之(五)| 模拟登录wechat 1
- 如何评价分类模型性能?(足球荔枝)
- .sql文件如何执行_干货|一条SQL查询语句是如何执行的
- 轻松学DDD之二:如何高效消化知识
- Atitit mq的AMQP 协议 STOMP2 、MQTT3 等协议 MQTT,XMPP,STOMP,AMQP,WAMP 目录 1. AMQP in a Nutshell	1 2. MQTT概述
- [LeetCode][easy]Rank Transform of an Array
- java程序员的待遇_想学java,一般的java程序员的薪资待遇是多少?
- 方法(Method)
- python列表功能默写_python 1 默写用递归实现无限极分类 2 默写用树实现无限极分类...
- 三维导热问题的ADI-TDMA算法
- 制作一个简单七夕情人节表白网页(HTML+CSS)
- WebSocket通讯C#实例
- Vue - 判断终端是否为:IE内核、opera内核、苹果、谷歌内核、火狐内核、是否为移动终端、ios终端、android终端、是否为iPhone或者QQHD浏览器、是否iPad、是否微信、是否QQ