嗨,我正在做调查,我可以根据用户记录测验的进度
示例:用户遇到问题15/50时,他必须能够断开连接并继续在其停止的地方。
我设法将答案分配给用户,但不必担心进度。非常感谢
所以我在这里通过post方法得到了答案 我的controlleur来为用户保存答案。
class DefaultController extends Controller
{
/**
* @Route("/Reponse/thematique", name="thematique_reponse")
* @Method({"GET", "POST"})
*/
public function reponseThematique(Request $request)
{
//instance des repository
$userSlpRepo = $this->getDoctrine()->getRepository(UserSlp::class);
$reponseThematiqueRepo = $this->getDoctrine()->getRepository(Reponse_thematique::class);
$questionMangerRepo = $this->getDoctrine()->getRepository(Manger::class);//here all the questions
$em = $this->getDoctrine()->getManager();
$userSlp = $userSlpRepo->findOneByGaeaUserId($this->getUser()->getId());
$datas = $request->request->all();
foreach ($datas as $data => $value ){
$question = $questionMangerRepo->find($data);
$answer = new Reponse_thematique;
$answer->setManger($question);
$answer->setValue($value);
$answer->setUserSlp($userSlp);
$em->persist($answer);
$em->flush();
}
return new response('ok');
}
例如,我想与实体“ questionnaire-progress”建立关系,否则我们将有一个id,question_id,user_id以及为什么没有一个列,或者如果该问卷已完成,我们将放置一个布尔值。
>/**
* SurveyProgress
*
* @ORM\Table(name="survey_progress", indexes={@ORM\Index(name="IDX_7EF6B461B3FE509D",
* columns={"questionnaire_id"}), @ORM\Index(name="IDX_7EF6B4611E27F6BF",
* columns={"manger_id"}), @ORM\Index(name="IDX_7EF6B461FDDFEACC",
* columns={"userSlp_id"})})
* @ORM\Entity
*/
class QuestionnaireProgress
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var bool
*
* @ORM\Column(name="done", type="boolean", nullable=false)
*/
private $done;
/**
* @var \Question
*
* @ORM\ManyToOne(targetEntity="manger")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="question_id", referencedColumnName="id")
* })
*/
private $manger;
/**
* @var \Survey
*
* @ORM\ManyToOne(targetEntity="questionnaire")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="questionnaire_id", referencedColumnName="id")
* })
*/
private $questionnaire;
/**
* @var \UserSlp
*
* @ORM\ManyToOne(targetEntity="UserSlp")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="userSlp_id", referencedColumnName="id")
* })
*/
private $userslp;
}
答案 0 :(得分:0)
您可以在用户每次回答时保存答案。然后,您将存储此信息。
我想一个session = Session()
session.connection(execution_options={
"schema_translate_map": {"per_user": "account_one"}})
# will query from the ``account_one.user`` table
session.query(User).get(5)
包含一个Survey
的列表。然后,您可以获得问题的总数。
如果您在用户回答时保存了答案,则给定Question
和给定Reponse_thematique
的{{1}}数/总问题数将为您提供进度>