zoukankan      html  css  js  c++  java
  • Java中sql语句的引号问题

    1..sql语句

    在数据库中,当我们查询语句时,会使用类似的语句:

    1 Select * from userinfo where userid='1' or 1;
    2 
    3 Select * from userinfo where username="jfl";

    2.问题

    Java通常需要连接数据库(Mysql,Oracle等)进行操作,在查询语句块中经常会用到where子句,在这里我们需要注意引号问题。

    3.实例

    在java中,我们需要将where子句的关键词变成变量,例如userid,username之类的。显然,直接写成以下语句不符合要求:

     1 public static HashMap<String, String> selectDataGetRecordMap(String id) throws SQLException {
     2 
     3      String sql = "SELECT * FROM userinfo WHERE customerid =id or 'id' ";
     4             HashMap<String, String> map = GenericDaoOper.queryGetRecordMap(sql);
     5             return map;
     6         }
     7 
     8 Scanner sc=new Scanner(System.in);        
     9         System.out.println("请输入所需查询的id:");
    10         String id=sc.nextLine();
    11         System.out.println( inser.selectDataGetRecordMap(id));

    解决方法:

    1 id=>' "+id+" '
    2 
    3 Select * from userinfo where userid=' "+id+" ';

    注:单引号 双引号 +variable+双引号 单引号

  • 相关阅读:
    多线程按序打印1-100
    负载均衡算法
    day05_05 for循环、break语句
    day05_04 数据类型-数值、布尔值、字符串简介
    day05_03 字符串格式化
    day05_02 IDE介绍及设置
    小甲鱼零基础入门PYTHON
    day01_14.遍历数组
    day01_13.数组
    day01_11.break和continue
  • 原文地址:https://www.cnblogs.com/jfl-xx/p/4708550.html
Copyright © 2011-2022 走看看