通过JavaWeb在整个MySQL DB中进行关键字搜索的推荐方法

问题描述

我正在尝试通过 JSP 从我的整个 MysqL 数据库中实现 keyword search,如果我选择的方法效率低下,我很困惑:(

我已阅读有关 @R_84_4045@ion_schema内容,并发现所有列标​​签都在那里。

我已经尝试了下面的 sql 语句来生成所有可能的查询

SELECT CONCAT('SELECT * FROM ',table_schema,'.',table_name,' WHERE ',column_name,' LIKE ','searchString',';')
      FROM @R_84_4045@ion_schema.columns
      WHERE table_schema NOT IN ('@R_84_4045@ion_schema','MysqL','performance_schema')
      AND (column_type LIKE 'char(%'
      OR column_type LIKE 'varchar(%'
      OR column_type LIKE '%text')

并尝试使用 JSP 代码来获得所有可能的数据匹配。

<%
    String searchString =   "malayalam";
            searchString        =   "''%"+searchString+"%'' ";    
            ArrayList<String> queries =   new ArrayList<String>();
            String sql="SELECT CONCAT('SELECT * FROM ',"
                + "' WHERE ','"+searchString+"',';')"
                + "FROM @R_84_4045@ion_schema.columns "
                + "WHERE table_schema NOT IN ('@R_84_4045@ion_schema','performance_schema')"
                + "AND (column_type LIKE 'char(%'"
                + "OR column_type LIKE 'varchar(%'"
                + "OR column_type LIKE '%text')";
            try{
                DBConInfoSchema db =   new DBConInfoSchema();
                ResultSet rs    =   db.getData(sql);
                while(rs.next()){
                    queries.add(rs.getString(1));
                }
                for(int i=0;i<queries.size();i++){
                    DBConInfoSchema dCon    =   new DBConInfoSchema();
                    ResultSet rsDemo        =   dCon.getData(queries.get(i));
                    if(rsDemo.next()){
                        out.print("<br/>Data found n query-"+i+" ->     "+queries.get(i));
                    }
                    dCon.DBClose();
                }
            }catch(Exception w){
                out.print("excep<br/>"+w);
            }
%>

现在我得到了大量的查询列表。 我很困惑是好还是坏?! 考虑到效率,这种方法是不是很糟糕?

解决方法

在查询构建部分

SELECT CONCAT('SELECT * FROM ',table_schema,'.',table_name,' WHERE ',column_name,' LIKE ','searchString',';')
      FROM information_schema.columns
      WHERE table_schema NOT IN ('information_schema','mysql','performance_schema')
      AND (column_type LIKE 'char(%'
      OR column_type LIKE 'varchar(%'
      OR column_type LIKE '%text')

我已更新线路

WHERE table_schema NOT IN ('information_schema','performance_schema')

 WHERE table_schema IN ('<my_table_name>')

生成my_table_name中的所有搜索结果并保存到ArrayList并执行

ArrayList<String> queries =   new ArrayList<String>();
DBConInfoSchema db =   new DBConInfoSchema();
ResultSet rs    =   db.getData(sql_statement);
while(rs.next()){
  queries.add(rs.getString(1));
}

从那里我整理出所需的数据。

-希望这对某些人有所帮助。

注意:尽管它对我有用,但我仍然相信它的天真 纠正我 如果有更好的方法来实现这一点