Skip to content
Toggle navigation
Projects
Groups
Snippets
Help
yangxiujun
/
paidan_demo
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Settings
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit 68811cd2
authored
Aug 03, 2023
by
wangli
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mybatisplus to jpa
1 parent
f390e67c
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
103 additions
and
30 deletions
project-order/src/main/java/com/dituhui/pea/order/service/impl/WorkbenchServiceImpl.java
project-order/src/main/java/com/dituhui/pea/order/service/impl/WorkbenchServiceImpl.java
View file @
68811cd
package
com
.
dituhui
.
pea
.
order
.
service
.
impl
;
package
com
.
dituhui
.
pea
.
order
.
service
.
impl
;
import
cn.hutool.core.date.DateUtil
;
import
cn.hutool.core.date.DateUtil
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.dituhui.pea.common.Result
;
import
com.dituhui.pea.common.Result
;
import
com.dituhui.pea.order.dao.*
;
import
com.dituhui.pea.order.dao.OrderEventDao
;
import
com.dituhui.pea.order.dao.OrderInfoDao
;
import
com.dituhui.pea.order.dto.OrderChangeListDTO
;
import
com.dituhui.pea.order.dto.OrderChangeListDTO
;
import
com.dituhui.pea.order.dto.WorkbenchSummaryResp
;
import
com.dituhui.pea.order.dto.WorkbenchSummaryResp
;
import
com.dituhui.pea.order.entity.OrderEventEntity
;
import
com.dituhui.pea.order.entity.OrderEventEntity
;
import
com.dituhui.pea.order.entity.OrderInfoEntity
;
import
com.dituhui.pea.order.entity.OrderInfo
;
import
com.dituhui.pea.order.entity.OrderInfo
;
import
com.dituhui.pea.order.entity.OrderInfoEntity
;
import
com.dituhui.pea.order.service.WorkbenchService
;
import
com.dituhui.pea.order.service.WorkbenchService
;
import
lombok.extern.slf4j.Slf4j
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
...
@@ -17,8 +17,15 @@ import org.springframework.data.domain.PageRequest;
...
@@ -17,8 +17,15 @@ import org.springframework.data.domain.PageRequest;
import
org.springframework.data.domain.Pageable
;
import
org.springframework.data.domain.Pageable
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
javax.persistence.EntityManager
;
import
javax.persistence.TypedQuery
;
import
javax.persistence.criteria.CriteriaBuilder
;
import
javax.persistence.criteria.CriteriaQuery
;
import
javax.persistence.criteria.Predicate
;
import
javax.persistence.criteria.Root
;
import
java.time.LocalDate
;
import
java.time.LocalDate
;
import
java.util.*
;
import
java.util.*
;
import
java.util.stream.Collectors
;
@Slf4j
@Slf4j
@Service
@Service
...
@@ -28,10 +35,10 @@ public class WorkbenchServiceImpl implements WorkbenchService {
...
@@ -28,10 +35,10 @@ public class WorkbenchServiceImpl implements WorkbenchService {
private
OrderEventDao
orderEventDao
;
private
OrderEventDao
orderEventDao
;
@Autowired
@Autowired
private
OrderInfo
MPDao
orderInfoMP
Dao
;
private
OrderInfo
Dao
orderInfo
Dao
;
@Autowired
@Autowired
private
OrderInfoDao
orderInfoDao
;
private
EntityManager
entityManager
;
@Override
@Override
public
Result
<?>
getOrderChangeList
(
OrderChangeListDTO
.
Request
reqDTO
)
{
public
Result
<?>
getOrderChangeList
(
OrderChangeListDTO
.
Request
reqDTO
)
{
...
@@ -89,27 +96,95 @@ public class WorkbenchServiceImpl implements WorkbenchService {
...
@@ -89,27 +96,95 @@ public class WorkbenchServiceImpl implements WorkbenchService {
}
}
private
List
<
Map
<
String
,
Object
>>
queryCountByAppointmentMethod
(
String
levelType
,
String
levelValue
,
LocalDate
dt
)
{
private
List
<
Map
<
String
,
Object
>>
queryCountByAppointmentMethod
(
String
levelType
,
String
levelValue
,
LocalDate
dt
)
{
QueryWrapper
<
OrderInfo
>
wrapper
=
new
QueryWrapper
<>();
CriteriaBuilder
criteriaBuilder
=
entityManager
.
getCriteriaBuilder
();
wrapper
.
select
(
"appointment_method, appointment_status, COUNT(*) as count"
)
CriteriaQuery
<
Object
[]>
criteriaQuery
=
criteriaBuilder
.
createQuery
(
Object
[].
class
);
.
lambda
()
Root
<
OrderInfo
>
root
=
criteriaQuery
.
from
(
OrderInfo
.
class
);
.
eq
(
OrderInfo:
:
getDt
,
dt
)
.
eq
(
levelType
.
equals
(
"cluster"
),
OrderInfo:
:
getOrgClusterId
,
levelValue
)
criteriaQuery
.
multiselect
(
.
eq
(
levelType
.
equals
(
"branch"
),
OrderInfo:
:
getOrgBranchId
,
levelValue
)
root
.
get
(
"appointmentMethod"
),
.
eq
(
levelType
.
equals
(
"group"
),
OrderInfo:
:
getOrgGroupId
,
levelValue
)
root
.
get
(
"appointmentStatus"
),
.
groupBy
(
OrderInfo:
:
getAppointmentMethod
,
OrderInfo:
:
getAppointmentStatus
);
criteriaBuilder
.
count
(
root
).
alias
(
"count"
)
return
orderInfoMPDao
.
selectMaps
(
wrapper
);
);
}
Predicate
datePredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"dt"
),
dt
);
private
List
<
Map
<
String
,
Object
>>
queryCountByOrderStatus
(
String
levelType
,
String
levelValue
,
LocalDate
dt
)
{
Predicate
levelPredicate
=
null
;
QueryWrapper
<
OrderInfo
>
wrapper
=
new
QueryWrapper
<>();
wrapper
.
select
(
"service_status, COUNT(*) as count"
)
if
(
"cluster"
.
equals
(
levelType
))
{
.
lambda
()
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgClusterId"
),
levelValue
);
.
eq
(
OrderInfo:
:
getDt
,
dt
)
}
else
if
(
"branch"
.
equals
(
levelType
))
{
.
eq
(
levelType
.
equals
(
"cluster"
),
OrderInfo:
:
getOrgClusterId
,
levelValue
)
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgBranchId"
),
levelValue
);
.
eq
(
levelType
.
equals
(
"branch"
),
OrderInfo:
:
getOrgBranchId
,
levelValue
)
}
else
if
(
"group"
.
equals
(
levelType
))
{
.
eq
(
levelType
.
equals
(
"group"
),
OrderInfo:
:
getOrgGroupId
,
levelValue
)
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgGroupId"
),
levelValue
);
.
groupBy
(
OrderInfo:
:
getServiceStatus
);
}
return
orderInfoMPDao
.
selectMaps
(
wrapper
);
if
(
levelPredicate
!=
null
)
{
criteriaQuery
.
where
(
datePredicate
,
levelPredicate
);
}
else
{
criteriaQuery
.
where
(
datePredicate
);
}
criteriaQuery
.
groupBy
(
root
.
get
(
"appointmentMethod"
),
root
.
get
(
"appointmentStatus"
));
TypedQuery
<
Object
[]>
typedQuery
=
entityManager
.
createQuery
(
criteriaQuery
);
List
<
Object
[]>
results
=
typedQuery
.
getResultList
();
List
<
Map
<
String
,
Object
>>
mappedResults
=
results
.
stream
()
.
map
(
result
->
{
Map
<
String
,
Object
>
map
=
Map
.
of
(
"appointmentMethod"
,
result
[
0
],
"appointmentStatus"
,
result
[
1
],
"count"
,
result
[
2
]
);
return
map
;
})
.
collect
(
Collectors
.
toList
());
return
mappedResults
;
}
public
List
<
Map
<
String
,
Object
>>
queryCountByOrderStatus
(
String
levelType
,
String
levelValue
,
LocalDate
dt
)
{
CriteriaBuilder
criteriaBuilder
=
entityManager
.
getCriteriaBuilder
();
CriteriaQuery
<
Object
[]>
criteriaQuery
=
criteriaBuilder
.
createQuery
(
Object
[].
class
);
Root
<
OrderInfo
>
root
=
criteriaQuery
.
from
(
OrderInfo
.
class
);
criteriaQuery
.
multiselect
(
root
.
get
(
"serviceStatus"
),
criteriaBuilder
.
count
(
root
).
alias
(
"count"
)
);
Predicate
datePredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"dt"
),
dt
);
Predicate
levelPredicate
=
null
;
if
(
"cluster"
.
equals
(
levelType
))
{
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgClusterId"
),
levelValue
);
}
else
if
(
"branch"
.
equals
(
levelType
))
{
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgBranchId"
),
levelValue
);
}
else
if
(
"group"
.
equals
(
levelType
))
{
levelPredicate
=
criteriaBuilder
.
equal
(
root
.
get
(
"orgGroupId"
),
levelValue
);
}
if
(
levelPredicate
!=
null
)
{
criteriaQuery
.
where
(
datePredicate
,
levelPredicate
);
}
else
{
criteriaQuery
.
where
(
datePredicate
);
}
criteriaQuery
.
groupBy
(
root
.
get
(
"serviceStatus"
));
TypedQuery
<
Object
[]>
typedQuery
=
entityManager
.
createQuery
(
criteriaQuery
);
List
<
Object
[]>
results
=
typedQuery
.
getResultList
();
List
<
Map
<
String
,
Object
>>
mappedResults
=
results
.
stream
()
.
map
(
result
->
{
Map
<
String
,
Object
>
map
=
Map
.
of
(
"serviceStatus"
,
result
[
0
],
"count"
,
result
[
1
]
);
return
map
;
})
.
collect
(
Collectors
.
toList
());
return
mappedResults
;
}
}
private
HashMap
<
String
,
Long
>
transAppointmentMethod
(
List
<
Map
<
String
,
Object
>>
results
)
{
private
HashMap
<
String
,
Long
>
transAppointmentMethod
(
List
<
Map
<
String
,
Object
>>
results
)
{
...
@@ -211,12 +286,10 @@ public class WorkbenchServiceImpl implements WorkbenchService {
...
@@ -211,12 +286,10 @@ public class WorkbenchServiceImpl implements WorkbenchService {
return
items
;
return
items
;
}
}
private
<
T
>
HashMap
<
String
,
List
<
T
>>
packParams
(
String
key
,
T
...
values
)
{
private
<
T
>
HashMap
<
String
,
List
<
T
>>
packParams
(
String
key
,
T
...
values
)
{
HashMap
<
String
,
List
<
T
>>
map
=
new
HashMap
<>();
HashMap
<
String
,
List
<
T
>>
map
=
new
HashMap
<>();
List
<
T
>
value
=
new
ArrayList
<>();
List
<
T
>
value
=
new
ArrayList
<>();
for
(
T
v:
values
){
Collections
.
addAll
(
value
,
values
);
value
.
add
(
v
);
}
map
.
put
(
key
,
value
);
map
.
put
(
key
,
value
);
return
map
;
return
map
;
}
}
...
...
Write
Preview
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment