为何这里的语句、查询语句要加引号呢?是不是所有的查询语句都要加引号啊

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为何这里的语句、查询语句要加引号呢?是不是所有的查询语句都要加引号啊相关的知识,希望对你有一定的参考价值。

strQuery = "select * from yaopin where 产地='吉林'"

引号一般都是要加的,一般数字类型的字段可以不加,在db2 9.5以下的版本数字类型的不能加单引号,oracle中所有类型的都可以加单引号,最外层的双引号必须加 参考技术A 最外层的双引号是必须的,程序里sql语句是一串字符
如果直接在数据库工具里查询就不需要,直接select * from yaopin where 产地='吉林'
参考技术B 学编程我们知道字符串变量必须要用定界符(比如引号等)扩起来。
这里的SQL语句会作为字符串赋值给变量strQuery,所以要加引号。

Java中sql语句的引号问题

1..sql语句

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

Select * from userinfo where userid=‘1‘ or 1;

Select * from userinfo where username="jfl";

2.问题

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

3.实例

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

public static HashMap<String, String> selectDataGetRecordMap(String id) throws SQLException {

     String sql = "SELECT * FROM userinfo WHERE customerid =id or ‘id‘ ";
            HashMap<String, String> map = GenericDaoOper.queryGetRecordMap(sql);
            return map;
        }

Scanner sc=new Scanner(System.in);        
        System.out.println("请输入所需查询的id:");
        String id=sc.nextLine();
        System.out.println( inser.selectDataGetRecordMap(id));

解决方法:

id=>‘ "+id+" ‘

Select * from userinfo where userid=‘ "+id+" ‘

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

以上是关于为何这里的语句、查询语句要加引号呢?是不是所有的查询语句都要加引号啊的主要内容,如果未能解决你的问题,请参考以下文章

在mysql语句中为什么要加反引号

EL表达式${}里外要不要加双引号问题?

sql语句引号用法 数据库中引号的用法

SQL语句update中的where条件的用法问题

SQL语句中有关单引号双引号和加号的问题

使用select a.*,a.rowid from 表 a 查询语句时,为何“a.”后面不能列出字段项