这是Postgresql 9.2.4的设置:
CREATE TABLE table (
id integer NOT NULL,
some_text text
);
Run Code Online (Sandbox Code Playgroud)
现在我们输入一个记录,其中包含null或空字符串some_text,以便在我们查询时:
SELECT * FROM table WHERE some_text IS NULL;
Run Code Online (Sandbox Code Playgroud)
我得到了回来.到现在为止还挺好.
但是,当我查询时:
SELECT * FROM table WHERE some_text NOT ILIKE "%anything%';
Run Code Online (Sandbox Code Playgroud)
我发现没有任何回复.这是为什么?我希望null或空字符串"不喜欢anything".
我正在使用带有CellEditing插件的ExtJs Grid.它完美地工作,除了当我对其施加的验证失败时失去无效值.
例如,如果我在网格中有一个不允许超过10个字符的值的可编辑文本字段,并且用户输入" olympicssucks ",则验证将失败,并且文本字段周围将出现一个红色框.当用户点击该字段时,值" olympicssucks "将丢失.
我希望网格仍然保存无效数据,并保持周围的红色框.
另一个(可能更清楚)示例: http ://dev.sencha.com/deploy/ext-4.0.0/examples/grid/cell-editing.html尝试编辑第一个单元格值:" Adder's-Tongue "并将其设为空.请注意红色框和验证消息.现在点击开箱即可.失败的验证将恢复细胞恢复到原来的价值,Adder's舌.
tl; dr:我的问题,重申,是我想保留无效值,但仍然有验证显示它周围的红色框.我确信它可能,但它是如何完成的?
我尝试过的:
码:
var cellEditing = Ext.create('Ext.grid.plugin.CellEditing', {
clicksToEdit: 1
});
var grid = {
xtype: 'grid', store: dataStore, plugins: [cellEditing],
columns: [
{
text: 'Items', dataIndex: 'items', flex: 1, sortable : false,
editor: { …Run Code Online (Sandbox Code Playgroud)