我在MySQL数据库中保存日期时遇到问题。 测试一切:
我想在MySQL数据库中保存2010-01-01(例如)。 首先,我将MySQL字段设置为日期。这没用。但是当我将字段设置为字符串类型时,它会将日期保存在数据库中。
当我想将日期保存到日期字段时,为什么它不起作用?
虽然我认为代码在这里并不重要,但我会在请求后发布代码。
我使用zf 1.9.6
class JS_Form_EventForm extends ZendX_JQuery_Form{
public function init($options=null){
//parent::__construct($options);
$this->setName("newEvent");
$this->addElementPrefixPath('JS_Validate','JS/Validate/','validate');
//naam
$evtName = new Zend_Form_Element_Text("evt_name");
$evtName->setLabel("Evenement Naam: ")
->setRequired(true);
// omschrijving
$evtDescription = new Zend_Form_Element_Textarea("evt_description",array("rows"=>6,"cols"=>25));
$evtDescription->setLabel("Evenement omschrijving: ");
// locatie
$evtAdr = new Zend_Form_Element_Select("adr_id");
$evtAdr->setLabel("Locatie: ");
$locaties = $this->getLocations();
$evtAdr->setMultiOptions($locaties);
$newAdr = new Zend_Form_Element_Button("new_adr");
$newAdr->setLabel("+");
// begin datum
$evtStartDate = new ZendX_JQuery_Form_Element_DatePicker("evt_startdate",array("label"=> "Begin Datum"));
$evtStartDate->setJQueryParam('dateFormat', 'dd-mm-yy');
$evtStartDate->addValidator(new Zend_Validate_Date('dd-mm-YYYY'));
// eind datum
$evtEndDate = new ZendX_JQuery_Form_Element_DatePicker("evt_enddate",array("label"=> "Eind Datum"));
$evtEndDate->setJQueryParam('dateFormat', 'dd-mm-yy');
$evtEndDate->addValidator(new Zend_Validate_Date('dd-mm-YYYY'));
$evtEndDate->addValidator('CompareDates',false,array('evt_startdate'));
// begin tijd
$evtStartTime = new Zend_Form_Element_Text("evt_starttime");
$evtStartTime->setLabel("Begin Tijd");
$evtStartTime->addValidator(new Zend_Validate_Date('hh:mm',new Zend_Locale('auto')));
// eind tijd
$evtEndTime = new Zend_Form_Element_Text("evt_endtime");
$evtEndTime->setLabel("Eind tijd");
$evtEndTime->addValidator(new Zend_Validate_Date('hh:mm'));
// aantal personen
$amountPersons = new Zend_Form_Element_Text("evt_amtpersons");
$amountPersons->setLabel("Aantal personen nodig ");
$save = new Zend_Form_Element_Submit("save");
$save->setLabel("Opslaan");
$this->addElements(array($evtName,$evtDescription,$evtAdr,$newAdr,$evtStartDate,$evtEndDate,$evtStartTime,$evtEndTime,$amountPersons,$save));
$this->setMethod('post');
$this->setAction(Zend_Controller_Front::getInstance()->getBaseUrl().'/events/add');
}
保存数据:
public function addAction()
{
// action body
$form = new JS_Form_EventForm();
if(!$this->getRequest()->isPost()){
$this->view->form = $form;
}else{
$formdata = $this->_request->getPost();
if(!$form->isValid($formdata)){
$this->view->form = $form;
}else{
//http://zendgeek.blogspot.com/2009/07/zend-framework-building-complete.html
unset($formdata['save']);
$formdata['evt_name'] = ucfirst($formdata['evt_name']);
$e = new JS_Model_events();
$e->insert($formdata);
if($e ==true){
$this->_redirect('events/list');
}else{
echo 'Iets gaat niet goed';
}
/*
$formdata['sts_id'] = 1;
$eventsTable = new JS_Model_DbTable_events();
$eventsTable->insert($formdata);
*/
die();
// form valid process data
}
}
}
class JS_Model_DBTable_Events extends Zend_Db_Table_Abstract{
protected $_name = 'events';
public function remove($id){
if(isset($id)){
$where = $this->getAdapter()->quoteInto('evt_id = ?', $id);
return($this->delete($where));
}else{
return false;
}
}
/*
* function selectOne
* @param int id the id of the event to select
* @return resultset.
*/
public function selectOneRow($id){
//$where = $this->getAdapter()->quoteInto('evt_id = ?', $id);
//$query = $this->select($where);
//$result= $this->fetchRow($query);
$select = $this->select();
$select->where('evt_id = ?', $id);
$rows = $this->fetchAll($select);
return($rows);
}
}
答案 0 :(得分:3)
我猜这是导致问题的原因:
$evtStartDate->addValidator(new Zend_Validate_Date('dd-mm-YYYY'));
MySQL不了解dd-mm-YYYY
格式的日期文字。 MySQL理解YYYY-MM-DD
或YY-MM-DD
以及其他一些变体。
有关接受的日期文字格式的官方文档,请参阅http://dev.mysql.com/doc/refman/5.1/en/datetime.html。
评论:您可以在PHP代码中转换日期,也可以使用STR_TO_DATE()
MySQL函数插入表达式。传递Zend_Db_Expr
对象代替文字值。
$startdate_expr = $this->getAdapter()->quoteInto("STR_TO_DATE(?, '%d-%m-%Y')",
$formdata["evt_startdate"]);
$formdata["evt_startdate"] = new Zend_Db_Expr($startdate_expr);
$enddate_expr = $this->getAdapter()->quoteInto("STR_TO_DATE(?, '%d-%m-%Y')",
$formdata["evt_enddate"]);
$formdata["evt_enddate"] = new Zend_Db_Expr($enddate_expr);
$e->insert($formdata);
或者您可以更改Web应用程序的表单,要求日期为YYYY-MM-DD
格式,然后您不必转换任何内容。