对phalcom框架不了解的朋友可以点击了解下。
phalcon框架使用指南
在使用phalcon的insert和update功能时,因为数据库所有的字段设置的都是NOT NULL,而phalcon的model在插入或更新之前会自动判断字段是否需要必填,因此导致有空字段时无法存入。
开始遇到这问题时,想到两种解决方法:
一、改数据库字段,把NOT NULL改为可以为空。
但该数据库还得去找DBA,而且为了性能,DBA要求一般没有特殊情况,字段必须是NOT NULL,所以该方案否决。
二、给可以为空的字段设置默认值。
想过各种默认值,觉得空格最符合,但是赋值空格后,数据库里存的也会是空格,像一些empty和==''等判断会失效,很可能会影响一些业务逻辑,想想,还是放弃该方案。
最后还是上网各种搜,phalcon的资料太少,百度根本搜不出来,最后转战google,功夫不负有心人,终于给我找到些蛛丝马迹,最后再根据蛛丝马迹找出来真正的解决方案。同样有两种,如下:
一、给可以为空的字段单独设置规则
public function skipValidation($skipers=[]) { foreach ($skipers as $skiper) { if (empty($this->$skiper)) { $this->$skiper = new \Phalcon\Db\RawValue('""'); } } }
使用的时候:
public function beforeValidation() { $this->skipValidation(['tag','source_url']); }
这种方法可以完美解决问题,比较麻烦的是,需要设置每个可以为空的字段。
二、关闭phalcon对字段是否为空的判断
public function initialize(){ $this->setup( array('notNullValidations'=>false) ); }
该方法直接把底层判断字段是否为空的逻辑关闭了,可以一劳永逸的解决这个问题,缺点就是,自己前后台得做好必填字段的判断。
每次鼠标左键单击,递增,因此值始终在变化。我想要显示在条目字段,但我无法实现这一点。 如何使输入字段始终更新并在?
问题内容: 问候,我有这个输入字段, 我想在单击提交按钮时调用IsEmpty函数。 我尝试了下面的代码,但是没有用。有什么建议吗? 问题答案:
我使用了Gson,但我需要转换器只序列化非空值或非空值。 例如: 现在,将该对象转换为json的Gson实例如下所示
我有一个表,有多条记录具有相同的ID但不同的值。我想从其他表复制记录到这个表。如果记录为空,我想更新到最小位置,或者如果值不存在,插入到下一个位置。 这是我的目标表: ID|职位|价值 1 | 1 | A 2 | 1 | B 2 | 2 |空 2 | 3 |空 2 | 4 | C 3 | 1 | A 4 | 1 | D 4 | 2 | B 源表: ID |值 1 | C 2|N 3 | B 4 |
问题内容: 我有一条更新语句,用于更新ID = xx的字段x,y和z。 在表中,我有几个不同的x_created_datetime字段(用于由不同人员维护/输入的记录的不同部分)。我想编写一个查询,如果为null则将更新此字段,但如果不为null则将其保留。 所以我有: 我需要的是一种添加以下内容的方法,但始终会更新上面的内容: 我希望我可以在不进行第二次事务处理的情况下就可以做到这一点。关于如何
我想知道是否有一个衬里可能像这样 我只是检查名字、姓氏等是否为空。如果我有几个这样的字段呢? 因此,如果我写入,我不想用空值更新任何字段 如果我的字段为空,是否有任何可能的替代方案可以告诉object spread或任何其他内容不要更新?