永发信息网

ecshop 后台恢复之前的备份数据出错,代码如下,求解决!

答案:2  悬赏:80  手机版
解决时间 2021-02-01 11:12
MySQL server error report:Array
(
[0] => Array
(
[message] => MySQL Query Error
)

[1] => Array
(
[sql] => INSERT INTO `ecs_keywords` ( `date`,
`searchengine`, `keyword`, `count` ) VALUES ('2013-08-27', 'BAIDU',
NULL, '1')
)

[2] => Array
(
[error] => Column 'keyword' cannot be null
)

[3] => Array
(
[errno] => 1048
)

)
最佳答案
Column 'keyword' cannot be null
keyword不能为空!
INSERT INTO `ecs_keywords` ( `date`,
`searchengine`, `keyword`, `count` ) VALUES ('2013-08-27', 'BAIDU',
NULL, '1')
你这里提交了一个空值
你修改下 要么再提交的数据加个值 要么把keyword改为可为空!
全部回答

 在网站建设中,程序运行速度和网页下载速度都是关系成败的重要因素。作为一名web程序员,应该更加注意代码的运行速度。下面介绍的几种方法都在不同程度上提高了代码的运行速度。

  1.使用内嵌的html代码,而不是php的echo语句。

  因为php是一门嵌入式web编程语言,可以将html代码和php代码相互嵌入。但是很多程序员担心在html代码中过多的使用""嵌入php代码会多次调用php解释器,从而降低了php代码的运行速度,所以宁愿使用php的echo语句来输出html代码,而不直接使用html代码。但事实却恰恰相反。每一个php页面只调用一次php解释器来解释所有的php代码,所以,只在需要时才嵌入php代码,而大多数的时候直接使用html代码输入结果,不但不会降低程序的运行速度,而且因为减少了对echo语句的解析,往往可以提高代码的运行速度。

  2.使用str-replace而不是ereg-replace

  习惯使用perl进行编程的程序员更加愿意使用ereg_replace完成字符串替换工作,因为在php中ereg_replace的用法和perl中模式匹配的用法相近。但是,下面的这段代码证明,使用str_replace 代替 ereg_replace将可以大大提高代码的运行速度。

  测试str_replace和ereg_replace的运行速度

//这段代码测试str_replace的运行速度

<?php

for ($i=0; $i<1000; $i++) {  str_replace("a.$i", "b.$i", $string) ; }

//这段代码测试ereg_replace的运行速度

for ($i=0; $i<1000; $i++) {  ereg_replace(<([/]*)i>, <\1b>, $string); } ?>

//打印结果   使用str_replace的时间 - 0.089757   使用ereg_pattern的时间 - 0.248881 从运行的结果我们可以看出使用str_replace替代ereg_replace作为字符串替换函数,极大地提高了代码的运行速度。

  3.注意字符串的引用

  php和其它很多编程语言一样,可以使用双引号("")来引用字符串,也可以使用单引号('')。但是在php中,如果使用双引号来引用字符串,那么php解析器将首先分析字符串中有没有对变量的引用,有变量的话,将对变量进行替换。如果是单引号,则没有如此复杂——直接将单引号包含起来的所有字符串直接显示出来。显然,在php编程中,如果使用单引号引用字符串变量要比使用双引号快速一些。

  4.在数据库中避免使用联合操作

  比起其它的web编程语言来说,php的数据库功能十分强大。但是在php中数据库的运行仍然是一件十分费时费力的事情,所以,作为一个web程序员,要尽量减少数据库的查询操作,同时应该为数据库建立适当的索引。另一件值得注意的事情是在用php操作数据库时,尽可能不使用多个数据表的联合操作,尽管联合操作可以增强数据库的查询功能,但是却大大增加了服务器的负担。

  为了说明这个问题,我们可以看看下面的这个简单的例子。

  我们在数据库中创建了两个数据表foo和big_foo。在数据表foo中,只有一个字段,包含了从1-1000之间的所有自然数。数据表big_foo同样只有一个字段,但包含了从1-1,000,000之间的全部自然数。所以,从大小上说,big_foo等于foo与它自身进行了联合操作。

$db->query("select * from foo"); 0.032273 secs $db->next_record(); 0.00048999999999999 secs $db->query("insert into foo values (null)"); 0.019506 secs $db->query("select * from foo as a, foo as b"); 17.280596 secs $db->query("select * from foo as a, foo as b where a.id > b.id"); 14.645251 secs $db->query("select * from foo as a, foo as b where a.id = b.id"); 0.041269 secs $db->query("select * from big_foo"); 25.393672 secs   从上面操作结果我们可以发现,对于两个有1000条记录的数据表进行联合,其速度并不比对一个1000000条纪录的大型数据表单独进行操作快多少。 php学习之家

  5.注意include与require的区别

  在php变成中,include()与require()的功能相同,但在用法上却有一些不同,include()是有条件包含函数,而require()则是无条件包含函数。例如在下面的一个例子中,如果变量$somgthing为真,则将包含文件somefile: php学习之家

if($something){  include("somefile"); }   但不管$something取何值,下面的代码将把文件somefile包含进文件里:

if($something){  require("somefile"); }   下面的这个有趣的例子充分说明了这两个函数之间的不同。

$i = 1; while ($i < 3) {  require("somefile.$i");  $i++; }   在这段代码中,每一次循环的时候,程序都将把同一个文件包含进去。很显然这不是程序员的初衷,从代码中我们可以看出这段代码希望在每次循环时,将不同的文件包含进来。如果要完成这个功能,必须求助函数include():

$i = 1; while ($i < 3) {  include("somefile.$i");  $i++; }   6.注意echo和print的区别

  php中echo和print的功能也基本相同,但是两者之间也有细微差别。在php代码中可以把print作为一个普通函数来使用,例如执行下面的代码后变量$res的值将为1。

$ret = print "hello world";   这意味着print可用在一些复杂的表达式中,而echo则不行。同样,在代码中echo语句的运行速度要略微快于print语句,因为echo语句不要求返回任何数值。

我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
顺气的意思是什么啊?知道的请说下!
轶五帝之遐迹兮,蹑三皇之高踪 是什么意思?
产品销售的方式多元化,目的在于提高企业产品
佛山到肇庆怀集要多少钱啊
(12分)回答下列有关核酸的问题:(1)DNA大多
我朋友在翻牌机堂子跑车被刑拘了!请问一下会
地垠的意思是什么啊?知道的请说下!
(-60)*(3/4+5/6-11/15-7/12)
收到微信两笔相同数量的转账 其中一个点了立
what did she do?回答 she was ate turkey 可
凤縠的意思是什么啊?知道的请说下!
80平米水电改造多少钱 80平米水电如何改造
柳州广预宾馆地址好找么,我有些事要过去
迫卒的意思是什么啊?知道的请说下!
下水管道除臭技巧有哪些
推荐资讯
强虏的意思是什么啊?知道的请说下!
java super(i+1)是什么意思
权力的游戏雪诺是谁的儿子 雷加是谁 雪诺
罗布桑是什么意思
请问,服务器为什么1线无法登入啊?,线都可以
【我17岁了胸不大给你看】...想对那些曾被我
i3-2100 cpu 能玩最新版的lol么 一多开的程序
中国银行信用卡补卡制卡已成功,可以打电话加
淘宝里买手机有真货吗
苹果序列号C7CSP3P9HG75
绵阳办理营业执照需要多久?只说时间,不说流
天鸿教育中心地址有知道的么?有点事想过去
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?