初识thinkphp(4)
这次内容是数据库的使用方法
因为在第一章讲过就是拿index这个文件写的数据库的访问,这次实验我使用文件是系统默认的首页
配置的内容也在那里有提过就不重发戳图了。

数据库按照手册上的建议建了3行的内容(使用的SQLyog来进行连接的)

现在想想在配置databas.php这个文件时候有这么一段

当时想着这个有什么意义,我想这样大概能分模块引用数据库,不至于使得结构混乱
要访问数据库,要加上
use think\Db
接下来显示进行增删改查
<?php
namespace app\index\controller; use think\Controller;
use think\Db; class Index extends Controller
{
public function index()
{
$data = Db::execute('INSERT into think_data (id, data, status) value(7, "sijidou4", 1)');
var_dump($data);
$data = Db::execute('UPDATE think_data set data = "四季豆" where id = 4');
var_dump($data);
$result = Db::query('SELECT * from think_data');
dump($result);
echo "<br/>";
$data = DB::execute('DELETE from think_data where id = 7');
$result = Db::query('SELECT * from think_data');
dump($result);
echo "hello world";
return ;
}
}
execute执行操作,如果用var_dump将结果字符串输出,会显示“int()”之类的
而query操作会使结果返回一个数组,即可以显示表里字段的内容。
这里的代码可以精简下去掉execute操作(因为该操作不需要变量,也不需要输出),代码如下
<?php
namespace app\index\controller; use think\Controller;
use think\Db; class Index extends Controller
{
public function index()
{
Db::execute('INSERT into think_data (id, data, status) value(7, "sijidou4", 1)');
Db::execute('UPDATE think_data set data = "四季豆呀" where id = 4');
$result = Db::query('SELECT * from think_data');
dump($result);
echo "<br/>";
Db::execute('DELETE from think_data where id = 7');
$result = Db::query('SELECT * from think_data');
dump($result);
echo "hello world";
return ;
}
}
学到了一句SQL命令
// 清空数据表
Db::execute('TRUNCATE table think_data');
可以用DB::connect(数据库类型//账号:密码@地址:端口/库名#编码)来重新打开新的数据库。
可以用这种方式来表示打开不同数据库,且比较方便。
$db1 = Db::connect('db1');
$db2 = Db::connect('db2');
$db1->query('select * from think_data where id = 1');
$db2->query('select * from think_data where id = 1');
用[]来实现动态绑定,保护安全
例如
Db::execute('INSERT into think_data VALUES(?, ? ,?)',[7,'aaa',1]);
Db::execule('INSERT into think_data VALUES(:id, :data, :status),['id' => 7, 'data' => 'aaa', 'status' => 1]');
thinkphp5还提供一种查询构造器,即把每一步用函数来表示,并每个步骤间用->相连
//该代码来着官方文档(本人比较喜欢上面的原生态代码)
// 插入记录
Db::table('think_data')
->insert(['id' => 18, 'name' => 'thinkphp', 'status' => 1]); // 更新记录
Db::table('think_data')
->where('id', 18)
->update(['name' => "hello"]); // 查询数据
$list = Db::table('think_data')
->field('name,email')
->where('id', 18)
->select(); // 删除数据
Db::table('think_data')
->where('id', 18)
->delete();
注意下用select()进行查询,必须把select放在最后,之前放要进行select的对象的信息。
最先提到prefix这个设置表开头前缀的在这里可以有如下作用
Db::table('think_data') 等价于Db::name('data');
内容不多,今天就到这吧。
初识thinkphp(4)的更多相关文章
- 初识thinkphp(3)
这篇内容主要涉及请求相应内容. 该系列主要是个人笔记,且内容是连贯的,其中涉及到的自己写的模块或者方法在前面文章中有介绍咋来的,如果您看得云里雾里,给您带来不便,真的不好意思. 0x01:请求对象 官 ...
- 初识thinkphp(5)
这次主要内容是模型的基本操作 0x01:什么是模型 通过手册的阅览,笼统的说就是,把打开数据库等操作在另一个php文件中进行 以及对变量的规则具体细节,查询,取值等操作进行定义,方便在控制器中直接使用 ...
- 初识thinkphp(2)
thinkphp的url路径的表示格式为 http://ip/tp/public/index.php/模块/控制器/操作 这里url最后的操作就是类里面的函数. 0x01:url访问格式 官方文档中有 ...
- 初识thinkphp(1)
作为一名准备成为CTF里WEB狗的萌新,在做了3个月的CTF的web题后,发现自己php代码审计非常不过关,并且web的架构模式条理也十分的不清晰,于是抱着提高代码审计能力的态度在近期会去写一个简单的 ...
- ThinkPHP学习笔记(一)----初识ThinkPHP
在做微信开发的时候原本使用来yii框架,后续觉得yii虽然功能强大使用方便,但是整个框架太大了,不适合一些轻量级的开发:这个时候发现thinkphp这个框架,框架本身很小,只有几M,但麻雀虽小,但五脏 ...
- 使用ThinkPHP框架高速开发站点(多图)
使用ThinkPHP框架高速搭建站点 这一周一直忙于做实验室的站点,基本功能算是完毕了.比較有收获的是大概了解了ThinkPHP框架.写一些东西留作纪念吧.假设对于相同是Web方面新手的你有一丝丝帮助 ...
- 使用ThinkPHP框架高速发展网站(多图)
使用ThinkPHP框架高速搭建站点 这一周一直忙于做实验室的站点,基本功能算是完毕了.比較有收获的是大概了解了ThinkPHP框架.写一些东西留作纪念吧.假设对于相同是Web方面新手的你有一丝丝帮助 ...
- ThinkPHP Widget模块开发流程
初识ThinkPHP的Widget,现把模块开发的流程发布如下,也方便以后自己查阅: 一.新建数据库表self_modules,sql代码如下 CREATE TABLE `self_modules` ...
- [转]使用ThinkPHP框架快速开发网站(多图)
本文转自:http://blog.csdn.net/ruby97/article/details/7574851 这一周一直忙于做实验室的网站,基本功能算是完成了.比较有收获的是大概了解了ThinkP ...
随机推荐
- activiti复盘重推的一种简单实现方式:
activiti复盘重推的一种简单实现方式: 设置流程的每一步让用户选择,比如一共有6步完成,用户选择从第4步开始复盘重推,那么把原来的推演oldId和4传到后台, 首先,后台生成一个新的推演id n ...
- ssm框架中Controller层的junit测试_我改
Controller测试和一般其他层的junit测试可以共用一个BaseTest 一.BaseTest如下: @RunWith(SpringJUnit4ClassRunner.class) @WebA ...
- android 系统开发板挂载U盘
cat /proc/partitions 查看有u盘设备 df 查看挂载情况 iTOP4416开发板插入u盘,自动挂载到 /mnt/udisk1
- AngularJS 项目里使用echarts 2.0 实现地图功能
项目中有一页是显示全国地图, echarts官网的地图实例里,有一个模拟迁徙的实例,比较符合项目需求.所以大部分配置项是参考此实例. angular 就不过多介绍了, Google出品的mvc(或者说 ...
- Java基础-类加载机制与自定义类Java类加载器(ClassLoader)
Java基础-类加载机制与自定义类Java类加载器(ClassLoader) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 关于类加载器的概念和分类我就不再废话了,因为我在之前的笔 ...
- 网络报错:“The connection is not for this device.”
网络报错:“The connection is not for this device.” 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 记得在前几天工作的时候,有一个同时通过微信 ...
- 错误 1 无法将文件“obj\Debug\XXX.exe”复制到“bin\Debug\XXX.exe”。文件“bin\Debug\XXX.exe”正由另一进程使用,因此该进程无法访问该文件
在重新生成Windows服务的时候出现的这个问题,原因是因为你的Windows服务已经在运行了,你可以卸载掉这个服务,也可以在资源管理器里直接关闭.
- 对Property进行RACObserve
@property (assign,nonatomic) int price; @property (assign,nonatomic) int time; [RACObserve(self,pric ...
- 设计模式之Mixin模式
介绍 mixin模式就是一些提供能够被一个或者一组子类简单继承功能的类,意在重用其功能.在面向对象的语言中,我们会通过接口继承的方式来实现功能的复用.但是在javascript中,我们没办法通过接口继 ...
- 读书笔记:《思考的乐趣:Matrix67数学笔记》第4章 统计数据的陷阱
<思考的乐趣:Matrix67数学笔记>第4章讲了几个统计学上的陷阱,由于现在流行的大数据与统计学很有渊源,所以认真读了这一章,在<大数据时代>中指出只考虑相关性就够了,而不考 ...