java项目中如何实现多选项的模糊或者精确查询
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java项目中如何实现多选项的模糊或者精确查询相关的知识,希望对你有一定的参考价值。
在java中如何实现多选项的查询,如:时间、商品名、生厂商、仓库、商品数量等等,其中根据一个选项或多个选项来精确或者模糊查询。在业务逻辑中SQL语句应该如何实现?数据库为ORACLE 11g
时间、商品名、生厂商、仓库、商品数量 这几个量 你从前端传送到业务逻辑层的时候先判断 其是否为空 之后拼接SQL
String sql=“select * from 表 where “
if(shijian!=null||!“”.eqaues(shijian))
sql=sql+"shijian='+时间 +'"
大概是这个意思
eqaues 我写错了 不用eclipse 敲 我很多东西不会写 参考技术A select * from 表 where 条件
一个选项或多个选项:
多个条件 可以用 and 或者 or连接, and表示且 or表示或者
精确或者模糊查询
精确使用 = 模糊使用like 其中like有占位符 _ 和匹配符 %
占位符表示提一个字符,匹配符表示替代0个或者多个字符
模糊查询使用 “like" ,精确查询使用“=”.
拼接sql语句用 StringBuffer。
例如:
StringBuffer sql = new StringBuffer();
sql.append("");//引号里面放你的sql语句。 参考技术C StringBuffer sb
可以实现的,多个,输入,判断每个条件是否为空。
如果不为空append进sb,具体,你自己决定,反正,查询功能上,查询一条和多条。机理是类似的
参考技术D 针对时间可以用 between..and 来约束范围,同时Oracle的时间亦可以用大于等于小于等操作符。楼主的意思不大明白,你所说的多选是指一张表中的多个字段同时约束结果,还是一个字段中的约束一定范围。
如果是多个字段同时约束查询结果的话,这些字段约束条件间可以用and进行连接。
LDAP在JAVA中如何模糊查询
参考技术A /** * 获得LDAP连接(不通过连接池,直接获得连接) * @return * @throws Exception */ private javax.naming.directory.DirContext getDirContext() throws Exception DirContext ctx = null; java.util.Hashtable env = new java.util.Hashtable(); env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory"); env.put(Context.PROVIDER_URL, "ldap://localhost:389"); env.put(Context.SECURITY_AUTHENTICATION, "simple"); env.put(Context.SECURITY_PRINCIPAL, user); env.put(Context.SECURITY_CREDENTIALS, pwd); ctx = new InitialDirContext(env); return ctx; /** * 返回用户查询接口 * @param DN 查找范围 ou=test,dc=abcd,dc=com * @param filter 过滤条件 cn=* * @param myserach 搜索范围 * @return LDAP标准接口 * @throws Exception */ public javax.naming.NamingEnumeration getFilter(String DN,String filter,int myserach) throws Exception DirContext ctx = getDirContext(); try NamingEnumeration em; SearchControls con = new SearchControls(); con.setSearchScope(myserach); em = ctx.search(DN, filter, con); return em; finally // /** * 设置条件查找 * @param dn 查找的根结点 * @param filter 查找条件 * @param level 查找范围 * @return 返回一个由DN组成的JAVA STRING 列表 * @throws Exception */ public java.util.Vector getfilterNodes(String dn,String filter,int level) throws Exception java.util.Vector ve=new java.util.Vector(); NamingEnumeration em=getFilter(dn,filter,level); while(em!=null && em.hasMoreElements()) SearchResult rs=(SearchResult)em.nextElement(); String db=rs.getName(); if (db.trim().equals("")) ve.add(dn); else ve.add(db+","+dn); return ve; 查看原帖>>以上是关于java项目中如何实现多选项的模糊或者精确查询的主要内容,如果未能解决你的问题,请参考以下文章