盒子
盒子
文章目录
  1. 数据库里把数值存为 String,按数值大小排序
  2. 配合 SpringBoot + Mybatis
    1. 传一个数组(变量)来
    2. 传一个对象来
    3. SQL
    4. 传对象
      1. 使用对象的属性
      2. 把表中一个字段对应的多个字段连接起来
        1. concat()函数
        2. group_concat()函数
          1. as label
          2. group by
    5. 联合查询
    6. where 后面的一大段东西
      1. like
      2. or and ()
  3. 查询遇到空指针异常

springboot 开发遇到一些 SQL 问题

数据库里把数值存为 String,按数值大小排序

select * from experience_salary order by avg_salary+0 desc

字段后 +0 就可以啦

不过好像不这样也能排序来着…

配合 SpringBoot + Mybatis

传一个数组(变量)来

数组首先要转为 String 。

用自带的 toString() 转后需要去掉 []

1
2
String ids = jobIds.toString().replace("[", "").replace("]","");
List<JobInfo> jobs = Mapper对象.getRecommenedJobs(ids);
1
2
@Select("select * from job_info where id in (${jobIds})")
List<JobInfo> getRecommenedJobs(@Param("jobIds")String jobIds);

传非对象的数据,前面要加上 @Param("jobIds") 这种注解。

传一个对象来

1
2
3
4
5
6
7
8
9
@Select("select id,job_name,min_salary from 
(select job_id,
(
GROUP_CONCAT(label SEPARATOR ' ' )
)as label from job_image group by job_id
)A
join job_info on job_info.id=A.job_id
where (label like '%' #{jineng} '%' or job_name like '%' #{jineng} '%') and min_xueli like '%' #{xueli} '%' and min_salary >= #{min_salary} and job_name like '%' #{job_name} '%' ")
List<JobInfo> getRecommenedJobsBySqlQuery(JobAnalysis jobAnalysis);

这个略复杂,一层层来。

SQL

1
2
3
4
5
6
7
select id,job_name,min_salary from (
select job_id,(GROUP_CONCAT(label SEPARATOR ' ' ))as label from job_image group by job_id
)
A join job_info on job_info.id=A.job_id where (
label like '%' #{jineng} '%' or job_name like '%' #{jineng} '%'
)
and min_xueli like '%' #{xueli} '%' and min_salary >= #{min_salary} and job_name like '%' #{job_name} '%'

传对象

直接这样传参数就行啦。

List<JobInfo> getRecommenedJobsBySqlQuery(JobAnalysis jobAnalysis);

使用对象的属性

传来对象,使用方式,在 SQL 中用 #{value} 来调用对象的属性。

把表中一个字段对应的多个字段连接起来

concat()函数

  • 功能:将多个字符串连接成一个字符串
  • 语法:concat(str1, str2, …)

group_concat()函数

  • 功能:将group by产生的同一个分组中的值连接起来,返回一个字符串结果。
  • 语法:group_concat( [distinct] 要连接的字段 [ order by 排序字段 asc/desc ][ separator ‘分隔符’ ] )
  • 说明:通过使用 distinct 可以排除重复值。如果希望对结果中的值进行排序,可以使用order by子句。separator是一个字符串值,缺省为一个逗号。

比如说表(job_image)

1
2
3
4
5
job_id   label
1 吃饭
1 打豆豆
1 打游戏
1 写代码

select job_id, (GROUP_CONCAT(label SEPARATOR ' ' ))as label from job_image group by job_id )

显示效果

1
2
job_id   label
1 吃饭 打豆豆 打游戏 写代码
as label

后面的 as label 意思就是把查到并连接起来的东西命别名为 label

group by

以上面为例,意思就是按 job_id 分组排序

把表变一下

1
2
3
4
5
6
job_id   label
1 吃饭
1 打豆豆
1 打游戏
1 写代码
2 蹦迪

如果只执行此代码,结果为

1
2
3
job_id   label
1
2

哈哈~~

联合查询

联合查询就是为了

join job_info on job_info.id=A.job_id

在原 SQL 中 join 前有个 A ,其实是前面省略了 as ,即命别名

这里的意思就是把上面通过连接得到的字段和 id 当做一个新表 A。

整体回顾一遍,就是把表 job_image 重新组合(连接字段),命别名为 A

上面这行代码意思就是把表 A (别名)和 job_info 表联合在一起查询。

两个表间的桥梁就是 A.job_idiob_info.id

where 后面的一大段东西

like

  • 匹配方式:
    • %
    • _
    • []
    • [^]
  • 与 Mybatis 用

min_xueli like '%' #{xueli} '%'

因为混合变量(#{xueli}),所以要用这种方式添加匹配符。

or and ()

这种逻辑可以用括号来指定先后

查询遇到空指针异常

MyBatis 查询 返回结果为 int ,如果查不到就会返回 null ,而 int ,boolean 这类类型是不能赋值为 null 的,可以转化返回 Integer 。