欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

thinkphp/SAE/数据库操作/D方法 问题

程序员文章站 2022-05-12 10:26:38
...
本地的数据库中本来有一个mesg表,后来在这个表后面增加了一个字段maid。
在某个操作中使用
$mesg = D('Mesg');
dump($mesg);

模型里有:
protected $_map = array(
'user'=>'muser',
'content'=>'mcontent',
'time'=>'mtime',
'aid'=>'maid',
);

结果中有这个:
["fields:protected"] => array(8) {
[0] => string(3) "mid"
[1] => string(4) "muid"
[2] => string(5) "muser"
[3] => string(8) "mcontent"
[4] => string(5) "mtime"
[5] => string(4) "maid"//这个
["_autoinc"] => bool(true)
["_pk"] => string(3) "mid"
}

在本地里面是有maid字段的。
但是上传到sinaapp上面的时候,还是同样的操作,结果却是:
["fields":protected] => array(7) {
[0] => string(3) "mid"
[1] => string(4) "muid"
[2] => string(5) "muser"
[3] => string(8) "mcontent"
[4] => string(5) "mtime"
["_autoinc"] => bool(true)
["_pk"] => string(3) "mid"
}

而下面这个无论在本地还是sae上都是正常的:
["_map":protected] => array(4) {
["user"] => string(5) "muser"
["content"] => string(8) "mcontent"
["time"] => string(5) "mtime"
["aid"] => string(4) "maid"
}
本来sae上面的table也是没有那个字段的,后来增加了字段无效,我把所有表重新传上去也无效。
runtime删了很多次也是无效,不知道是什么原因造成的?

回复讨论(解决方案)

先确认 sae 端的表结构已经修改成功
待本地以 sae 方式调试成功后,重新提交整个项目

先确认 sae 端的表结构已经修改成功
待本地以 sae 方式调试成功后,重新提交整个项目

sae表结构是已经修改好的。
“待本地以sae方式调试成功”是什么意思?

先确认 sae 端的表结构已经修改成功
待本地以 sae 方式调试成功后,重新提交整个项目

我现在新建的第二个版本,然后把第一个版本的全部copy过去,然后就好了!!
谢谢!
但是我想知道是什么原因造成的?

在你的机器上你不是用 sae 方式调试的吗?

常规的项目入口文件
require './ThinkPHP/ThinkPHP.php';

SAE的项目入口文件
require './ThinkPHP/Extend/Engine/Sae.php';

先确认 sae 端的表结构已经修改成功
待本地以 sae 方式调试成功后,重新提交整个项目

还有我想问如果不弄第二个版本,怎样将第一个版本整个重新提交?
我不知道应该怎么重新提交。

在你的机器上你不是用 sae 方式调试的吗?

常规的项目入口文件
require './ThinkPHP/ThinkPHP.php';

SAE的项目入口文件
require './ThinkPHP/Extend/Engine/Sae.php';

嗯,这个明白了

还有我想问如果不弄第二个版本,怎样将第一个版本整个重新提交?
我不知道应该怎么重新提交。 你不是用 SVN 软件的吗?
在项目目录上右键-提交即可

引用 5 楼 的回复:

还有我想问如果不弄第二个版本,怎样将第一个版本整个重新提交?
我不知道应该怎么重新提交。
你不是用 SVN 软件的吗?
在项目目录上右键-提交即可

那样提交之后就是没有作用,还是一样有那个问题。
但是我重建一个版本问题就解决了。
不知道为什么。

我也遇到这个问题了。网上搜了下,说是KVDB缓存的问题。然后我禁用KVDB,重新开启,但还是出现这个情况。经过一番折腾才知道禁用KVDB并没有清空缓存,虽然禁用的时候也提示了,但是至少我的没有被清空,原因就不去纠结了。
你可以用下面的代码来查看你的KVDB的缓存内容
[code]$kv = new SaeKV();
$ret = $kv->init();
$ret = $kv->pkrget('', 100);
dump($ret);
[/code]

如果你禁用并重新开启KVDB后,运行上面代码仍然输出缓存内容,那说明KVDB的缓存还在。
复制下面的代码,执行后解决一切问题。
[code] $kv = new SaeKV(); //创建SaeKV对象
$ret = $kv->init(); //初始化
$ret = $kv->pkrget('', 100); //获取缓存内容(帮助文档注明了上限为100条)
$this->show('

当前KVDB缓存内容

');
dump($ret);
//遍历并删除
foreach ($ret as $key => $value) {
$ret = $kv->delete($key);
}
$this->show('
');
$this->show('

清空KVDB缓存后的内容

');
$ret = $kv->pkrget('', 100);
dump($ret);
if (!$ret){
$this->show('
');
$this->show('KVDB清空成功');
};
[/code]