TP add()获取插入行的id

本文介绍了在ThinkPHP框架中如何正确地获取通过add()方法新增数据的自增长ID。使用M()->getLastInsID()方法可以有效地解决这一问题。
$add=M("plat_order")->add($data);
echo $add;

add()方法插入成功之后  echo出来是 1,并不是插入行的id

插入成功之后返回的是1,主键也是自增长的

$add=M("plat_order")->add($data);
$a = M()->getLastInsID();
echo $a;

使用M()->getLastInsID()就可以获取add()方法插入成功后自增长的id值



这是CLI程序中的结构体以及数据库ADD函数,我想CLI的ADD还是直接使用这个ADD函数 //doh全局编辑状态 /* 编辑上下文结构体 */ typedef struct { unsigned server_id; // 服务器数字ID CFG_DOH_SERVER_T server; // 服务器配置 bool in_edit; // 编辑状态标志 } DOH_EDIT_CONTEXT; static DOH_EDIT_CONTEXT s_doh_edit_ctx = {0}; APPL_ERRCODE dmDohCfgServerAdd(const CFG_DOH_SERVER_T *ent) { APPL_ERRCODE ret = ERR_NO_ERROR; TPCONFIG_SET_INPUT st = {0}; INT64 maxScore = 0; unsigned id; char key[TPDATA_KEY_MAX_LEN] = {0}; char id_buf[16]; PFM_ENSURE_RET_VAL(ent, ERR_APPL_C_PARAM_INVALID); PFM_IF_FAIL_DONE(ret, tpConfig_setResourceInit(&st, TPCONFIG_INIT_ENTRY)); tpConfig_getMaxScore(TPZSET_DNSPROXY_DOH_SERVER, &maxScore); id = (ent->id && ent->id[0] != '\0') ? (unsigned)atoi(ent->id) : (unsigned)maxScore + 1; dmDohCfgServerKeyGetById(id, key, sizeof(key)); PFM_IF_FAIL_DONE(ret, tpConfig_objAddKeyScoreForSet(&st, TPCONFIG_INIT_ENTRY, key, id)); snprintf(id_buf, sizeof(id_buf), "%u", id); PFM_IF_FAIL_DONE(ret, tpConfig_objAddFieldStrForSet(&st, TPCONFIG_INIT_ENTRY, CFG_PROTO_DOH_F_ID, id_buf)); PFM_IF_FAIL_DONE(ret, tpConfig_objAddFieldStrForSet(&st, TPCONFIG_INIT_ENTRY, CFG_PROTO_DOH_F_NAME, ent->name)); PFM_IF_FAIL_DONE(ret, tpConfig_objAddFieldStrForSet(&st, TPCONFIG_INIT_ENTRY, CFG_PROTO_DOH_F_STATUS, ent->status)); PFM_IF_FAIL_DONE(ret, tpConfig_objAddFieldNumU8ForSet(&st, TPCONFIG_INIT_ENTRY, CFG_PROTO_DOH_F_CUSTOM, ent->custom)); PFM_IF_FAIL_DONE(ret, tpConfig_objAddFieldStrForSet(&st, TPCONFIG_INIT_ENTRY, CFG_PROTO_DOH_F_SERVER, ent->server)); tpConfig_addOperAndSubForSet(&st, TPCONFIG_OPER_ADD | TPCONFIG_OPER_PUB, DNSPROXYSHELL_SUB_NAME); tpConfig_addZsetNameForSet(&st, TPZSET_DNSPROXY_DOH_SERVER); PFM_IF_FAIL_DONE(ret, tpConfig_set(&st)); done: tpConfig_setResourceFree(&st); return (ret == PFM_ERR_C_OK) ? ERR_NO_ERROR : ret; }
最新发布
10-25
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值