2016-09-09 3 views
0

DB MySql에 대한 연결로 일부 사이트를 작성하려고하는데 다음 문제를 만났습니다. 초기 생성 된 문자열로 쿼리를 작성하면 MySql은 "따옴표를 제거해야합니다."와 같이 smth를 작성합니다. 내가 아닌 liniar 문자열 만 개체 형식 문자열을 dB로 보내 이해, 나는이 문제를 피할 수있는 방법 :문자열 쿼리에서 따옴표를 제거하십시오. JSP

<sql:setDataSource var="con" driver="com.mysql.jdbc.Driver" 
url="jdbc:mysql://localhost/PosPromo" 
user="root" password="qwerty"/> 

// here I am waiting an array of integers from another JSP page, they are ID in my DB 

<% String [] val =request.getParameterValues("aaa"); %> 
<% request.setAttribute("val",val); %> 

<%! String str=""; %> 
<% for (int j=0;j<val.length;j++){ 
    if (j==(val.length-1)){ 
     str+=" id="+String.valueOf(val[j]); 
     break; 
    } 
    str+=" id="+String.valueOf(val[j])+" OR";  
} 
%> 
<%str="SELECT * FROM action WHERE "+str+";";%> 

// here I obtain string smth like "SELECT * FROM action WHERE id=3;" which realy works in DB 

<c:set var="que" value="str"/> 

<sql:query dataSource="${con}" var="result"> 
    "${que}"; 
</sql:query> 

RUN을 여기에 당신은 당신의 SQL 구문에 오류가 있습니다 "비문을 표시하며 설명서를 확인 즉, "아래로

+0

하는'교체 시도"라인 1에서 ' "가야"'근처 사용할 수있는 권리 구문에 대한 MySQL 서버 버전에 해당하는 $ {케} "; '$ {que}'와 함께 사용합니다. 또한 당신의 str은'SELECT * FROM action where id = 3 OR'와 같을 것이다. –

답변

2

변경하여 SQL 태그 :

<sql:query dataSource="${con}" var="result"> 
    ${que} 
</sql:query> 
관련 문제