Merge branch 'szzh' of http://repository.trustie.net/xianbo/trustie2 into szzh
Conflicts: db/schema.rbdev_chuangbin
commit
05b9b26314
@ -0,0 +1,11 @@
|
|||||||
|
<% if @subPage_title && @subPage_title == l(:label_student_list)%>
|
||||||
|
<%= form_tag( searchmembers_course_path(@course), method: 'get',:class => "f_l",:style => "margin-left: 5px; ",:remote=>true) do %>
|
||||||
|
<%= text_field_tag 'name', params[:name], name: "name", :class => 'f_1', :style => "height:15px; float: left;"%>
|
||||||
|
<% if @group %>
|
||||||
|
<%= hidden_field "search_group_id", params[:search_group_id],:value => "#{@group.id}", name: 'search_group_id' %>
|
||||||
|
<%= submit_tag l(:label_search_member), :name => "ingroup",:class => "f_2", :style => "float: left "%>
|
||||||
|
<% else %>
|
||||||
|
<%= submit_tag l(:label_search_member),:style => "float: left", :name => 'incourse',:onclick => "checkclass('group_name_0')",:class => "f_2"%>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
@ -0,0 +1 @@
|
|||||||
|
$("#member_content").html("<%= escape_javascript( render :partial => @render_file, :locals => {:members => @members})%>");
|
@ -1,4 +1,5 @@
|
|||||||
/**
|
/**
|
||||||
* Created by Administrator on 2014/12/3.
|
* Created by Administrator on 2014/12/3.
|
||||||
*/
|
*/
|
||||||
|
$("#search_members").html("<%= escape_javascript( render :partial => 'searchmembers')%>");
|
||||||
$("#member_content").html("<%= escape_javascript( render :partial => @render_file, :locals => {:members => @results})%>");
|
$("#member_content").html("<%= escape_javascript( render :partial => @render_file, :locals => {:members => @results})%>");
|
@ -1,97 +1,100 @@
|
|||||||
|
#encoding=UTF-8
|
||||||
DELIMITER $$
|
class SelectMemberScore < ActiveRecord::Migration
|
||||||
|
def up
|
||||||
CREATE
|
sql = ("
|
||||||
/*[DEFINER = { user | CURRENT_USER }]*/
|
|
||||||
PROCEDURE `member_score`(IN courseid INT)
|
CREATE
|
||||||
/*LANGUAGE SQL
|
|
||||||
| [NOT] DETERMINISTIC
|
PROCEDURE `member_score`(IN courseid INT)
|
||||||
| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
|
|
||||||
| SQL SECURITY { DEFINER | INVOKER }
|
BEGIN
|
||||||
| COMMENT 'string'*/
|
|
||||||
BEGIN
|
CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
|
||||||
|
id INT
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
|
|
||||||
id INT
|
);
|
||||||
|
TRUNCATE TABLE course_teachers;
|
||||||
);
|
|
||||||
TRUNCATE TABLE course_teachers;
|
CREATE TEMPORARY TABLE IF NOT EXISTS mems (
|
||||||
|
id INT ,
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS mems (
|
user_id INT,
|
||||||
id INT ,
|
course_id INT,
|
||||||
user_id INT,
|
created_on DATETIME,
|
||||||
course_id INT,
|
course_group_id INT,
|
||||||
created_on DATETIME,
|
score FLOAT DEFAULT 0
|
||||||
course_group_id INT,
|
);
|
||||||
score FLOAT DEFAULT 0
|
TRUNCATE TABLE mems;
|
||||||
);
|
|
||||||
TRUNCATE TABLE mems;
|
CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
|
||||||
|
id INT,
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
|
user_id INT,
|
||||||
id INT,
|
course_id INT,
|
||||||
user_id INT,
|
created_on DATETIME,
|
||||||
course_id INT,
|
course_group_id INT,
|
||||||
created_on DATETIME,
|
home_id INT,
|
||||||
course_group_id INT,
|
score FLOAT DEFAULT 0
|
||||||
home_id INT,
|
);
|
||||||
score FLOAT DEFAULT 0
|
TRUNCATE TABLE mem_home;
|
||||||
);
|
|
||||||
TRUNCATE TABLE mem_home;
|
CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
|
||||||
|
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
|
home_id INT,
|
||||||
|
score FLOAT
|
||||||
home_id INT,
|
);
|
||||||
score FLOAT
|
TRUNCATE TABLE t_scores;
|
||||||
);
|
|
||||||
TRUNCATE TABLE t_scores;
|
CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
|
||||||
|
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
|
home_id INT,
|
||||||
|
score FLOAT
|
||||||
home_id INT,
|
);
|
||||||
score FLOAT
|
TRUNCATE TABLE s_scores;
|
||||||
);
|
|
||||||
TRUNCATE TABLE s_scores;
|
CREATE TEMPORARY TABLE IF NOT EXISTS scores (
|
||||||
|
|
||||||
CREATE TEMPORARY TABLE IF NOT EXISTS scores (
|
user_id INT,
|
||||||
|
score FLOAT
|
||||||
user_id INT,
|
);
|
||||||
score FLOAT
|
TRUNCATE TABLE scores;
|
||||||
);
|
|
||||||
TRUNCATE TABLE scores;
|
INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
|
||||||
|
|
||||||
INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
|
|
||||||
|
|
||||||
#查出所有的学生
|
INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
|
||||||
|
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
|
||||||
INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
|
FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
|
||||||
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
|
|
||||||
FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
|
INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
|
||||||
|
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
|
||||||
# 查出所有的学生列表及其作业
|
FROM members, homework_attaches WHERE course_id = courseid
|
||||||
INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
|
AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
|
||||||
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
|
AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
|
||||||
FROM members, homework_attaches WHERE course_id = courseid
|
|
||||||
AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
|
INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
||||||
AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
|
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
||||||
|
AND rater_id IN (SELECT id FROM course_teachers)
|
||||||
INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
GROUP BY rateable_id);
|
||||||
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
|
||||||
AND rater_id IN (SELECT id FROM course_teachers)
|
INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
||||||
GROUP BY rateable_id);
|
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
||||||
|
AND rater_id NOT IN (SELECT id FROM course_teachers)
|
||||||
INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
GROUP BY rateable_id) ;
|
||||||
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
|
||||||
AND rater_id NOT IN (SELECT id FROM course_teachers)
|
UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
|
||||||
GROUP BY rateable_id) ;
|
|
||||||
|
UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
|
||||||
UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
|
|
||||||
|
INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
|
||||||
UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
|
UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
|
||||||
|
|
||||||
INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
|
SELECT * FROM mems ORDER BY score DESC;
|
||||||
UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
|
END;
|
||||||
|
|
||||||
SELECT * FROM mems ORDER BY score DESC;
|
")
|
||||||
END$$
|
execute(sql)
|
||||||
|
end
|
||||||
DELIMITER ;
|
|
||||||
|
def down
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,100 @@
|
|||||||
|
class ProMemberScore < ActiveRecord::Migration
|
||||||
|
def up
|
||||||
|
sql_delete = ("DROP PROCEDURE IF EXISTS `member_score`;")
|
||||||
|
sql = ("
|
||||||
|
CREATE PROCEDURE `member_score`(IN courseid INT, IN groupid INT,IN start_from INT, IN nums INT)
|
||||||
|
BEGIN
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
|
||||||
|
id INT
|
||||||
|
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE course_teachers;
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS mems (
|
||||||
|
id INT ,
|
||||||
|
user_id INT,
|
||||||
|
course_id INT,
|
||||||
|
created_on DATETIME,
|
||||||
|
course_group_id INT,
|
||||||
|
score FLOAT DEFAULT 0
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE mems;
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
|
||||||
|
id INT,
|
||||||
|
user_id INT,
|
||||||
|
course_id INT,
|
||||||
|
created_on DATETIME,
|
||||||
|
course_group_id INT,
|
||||||
|
home_id INT,
|
||||||
|
score FLOAT DEFAULT 0
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE mem_home;
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
|
||||||
|
|
||||||
|
home_id INT,
|
||||||
|
score FLOAT
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE t_scores;
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
|
||||||
|
|
||||||
|
home_id INT,
|
||||||
|
score FLOAT
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE s_scores;
|
||||||
|
|
||||||
|
CREATE TEMPORARY TABLE IF NOT EXISTS scores (
|
||||||
|
|
||||||
|
user_id INT,
|
||||||
|
score FLOAT
|
||||||
|
);
|
||||||
|
TRUNCATE TABLE scores;
|
||||||
|
|
||||||
|
INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
|
||||||
|
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
|
||||||
|
FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
|
||||||
|
|
||||||
|
INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
|
||||||
|
(SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
|
||||||
|
FROM members, homework_attaches WHERE course_id = courseid
|
||||||
|
AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
|
||||||
|
AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
|
||||||
|
|
||||||
|
INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
||||||
|
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
||||||
|
AND rater_id IN (SELECT id FROM course_teachers)
|
||||||
|
GROUP BY rateable_id);
|
||||||
|
|
||||||
|
INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
|
||||||
|
FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
|
||||||
|
AND rater_id NOT IN (SELECT id FROM course_teachers)
|
||||||
|
GROUP BY rateable_id) ;
|
||||||
|
|
||||||
|
UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
|
||||||
|
|
||||||
|
UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
|
||||||
|
|
||||||
|
INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
|
||||||
|
UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
|
||||||
|
IF nums <> 0 THEN
|
||||||
|
SELECT * FROM mems ORDER BY score DESC LIMIT start_from, nums;
|
||||||
|
ELSE
|
||||||
|
SELECT * FROM mems WHERE course_group_id = groupid ORDER BY score DESC;
|
||||||
|
END IF;
|
||||||
|
END;
|
||||||
|
|
||||||
|
")
|
||||||
|
execute(sql_delete)
|
||||||
|
execute(sql)
|
||||||
|
end
|
||||||
|
|
||||||
|
def down
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in new issue