php thinkphp3。2怎么获取某数据库字段的内容?

php thinkphp3。2怎么获取某数据库字段的内容?,第1张

需要准备的材料分别是:电脑、php编辑器、浏览器。

1、首先,打开php编辑器,新建php文件,例如:index.php,以获取user表name字段为例。

2、在index.php中,输入代码:$User = M("User")$data = $User->field(['name'])->find()print_r($data)。

3、浏览器运行index.php页面,此时会打印出user表name字段的查询结果。

解决办法:

就是修改thinkphp的源码中的Library/Db/Driver.class.php文件,把

PDO::ATTR_CASE =>PDO::CASE_LOWER 改为 PDO::ATTR_CASE =>PDO::CASE_NATURAL,

或者在配置文件里面增加

DB_PARAMS’=> array(\PDO::ATTR_CASE =>\PDO::CASE_NATURAL) 这一句。

第一次使用的时候这种解决方法果然可以,但是做另外一个项目的时候却始终不生效,无奈,百度了半天,找到一个方法,因为thinkphp执行的时候默认会把大写转换成小写,所以我们找到它的源码不让它转换就行。

修改Common/functions.php里面的parse_name函数源码为:

function parse_name($name, $type=0) {

/* if ($type) {

return ucfirst(preg_replace_callback('/_([a-zA-Z])/', function($match){return strtoupper($match[1])}, $name))

} else {

//这里会将数据库表名里的大写转换为 _小写,修改成不转换

return strtolower(trim(preg_replace("/[A-Z]/", "_\\0", $name), "_"))

}*/

return $name

}

其中注释掉的是原来的,未注释是新增的。

修改Library/Think/Model.class.php里面的getTableName函数:

//$this->trueTableName= strtolower($tableName)//这里会将表名转换成小写,修改成不转换

$this->trueTableName= $tableName

修改其中一句,这样就可以解决数据库字段名大写的问题。

以thinkphp5.0为例。

小程序可以视为前端,使用异步请求(wx.request)的方式获取thinkphp(服务端)的接口。

thinkphp方面。只要设置好各个接口就行了。

在控制器中使用$this->result返回封装后的api数据到客户端(小程序)。返回的是json格式数据。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8125828.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存