admin
2021-03-06 7804263c6061aef813f0db27cb3046f746572606
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package com.yeshi.buwan.service.imp;
 
import com.yeshi.buwan.dao.VideoResourceDao;
import com.yeshi.buwan.domain.LeShiAccount;
import com.yeshi.buwan.domain.VideoInfo;
import com.yeshi.buwan.domain.VideoResource;
import com.yeshi.buwan.util.StringUtil;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import org.hibernate.HibernateException;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.springframework.orm.hibernate4.HibernateCallback;
import org.springframework.stereotype.Service;
 
import javax.annotation.Resource;
import java.util.Iterator;
import java.util.List;
 
@Service
public class VideoResourceService {
    @Resource
    private VideoResourceDao videoResourceDao;
 
    public List<VideoResource> getResourceList() {
        return videoResourceDao.list("from VideoResource");
    }
 
    public VideoResource getResource(String id) {
        return (VideoResource) videoResourceDao.find(VideoResource.class, id);
    }
 
    public void addResource(VideoResource re) {
        videoResourceDao.create(re);
    }
 
    public void deleteResource(String id) {
        VideoResource re = new VideoResource();
        re.setId(id);
        videoResourceDao.delete(re);
    }
 
    public void updateResource(VideoResource re) {
        videoResourceDao.update(re);
    }
 
    public String resourceListToJson(List<VideoResource> list, List<LeShiAccount> accountList) {
        JSONObject object = new JSONObject();
        JSONArray array = new JSONArray();
        VideoResource vr;
        for (Iterator<VideoResource> iterator = list.iterator(); iterator.hasNext(); array
                .add(StringUtil.outPutResultJson(vr)))
            vr = (VideoResource) iterator.next();
 
        object.put("Type", array);
        return object.toString();
    }
 
    public void excuteSQL(final String sql) {
        videoResourceDao.excute(new HibernateCallback() {
            public Object doInHibernate(Session session) throws HibernateException {
                session.getTransaction().begin();
                session.createSQLQuery(sql).executeUpdate();
                session.flush();
                session.getTransaction().commit();
                return null;
            }
        });
    }
 
    @SuppressWarnings("unchecked")
    public List<VideoResource> getResourceByVideo(final VideoInfo vi) {
 
        final String sql = "select vr.* from wk_video_resource vr left join wk_resource_video rv on vr.id=rv.resourceid where rv.videoid = ? ";
 
        return (List<VideoResource>) videoResourceDao.excute(new HibernateCallback<List<VideoResource>>() {
 
            @Override
            public List<VideoResource> doInHibernate(Session session)
                    throws HibernateException {
                SQLQuery query = session.createSQLQuery(sql);
                query.setParameter(0, vi.getId());
                query.addEntity(VideoResource.class);
                return query.list();
            }
        });
 
//        List<VideoResource> list = videoResourceDao.list("from VideoResource vr left join ResourceVideo rv where rv.juhe.id = ? and vr.id=rv.resource.id",new Serializable[]{vi.getId()});
    }
 
}