初识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 ...
随机推荐
- ubuntu 指定用户执行脚本
方法 创建可执行脚本 以下以脚本名称为superset.sh为例,具体的脚本内容大家可以自己发挥. cd ~ vi superset.sh # 脚本内容自己写好后保存 修改脚本权限 sudo chmo ...
- Java基础-SSM之Spring MVC入门篇
Java基础-SSM之Spring MVC入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Spring MVC简介 1>.什么是Spring MVC 答:Sprin ...
- Linux下/etc/passwd、/etc/shadow、/etc/group文件
1./etc/passwd [root@prac ~]# cat /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbi ...
- bzoj千题计划290:bzoj3143: [Hnoi2013]游走
http://www.lydsy.com/JudgeOnline/problem.php?id=3143 计算每条边经过的概率e[] 然后经过概率多的分配的编号大,经过概率少的分配的编号小 如何计算边 ...
- javascript构造函数模块
var Person = (function(){ var Constr; Constr = function(){ this.name = 'carl'; } Constr.prototype = ...
- Web性能优化系列(2):剖析页面绘制时间
本文由 伯乐在线 - J.c 翻译,sunbiaobiao 校稿.未经许可,禁止转载!英文出处:www.deanhume.com.欢迎加入翻译小组. 最近,我参加了在伦敦举办的Facebook移动开发 ...
- expect 交互 telnet 交互
telnet 交互 #!/bin/bash Ip="10.0.1.53" a="\{\'method\'\:\'doLogin\'\,\'params\'\:\{\'uN ...
- Hibernate常用的Java数据类型映射到mysql和Oracle
研究了常用的Java基本数据类型在mysql和oracle数据库的映射类型.这里使用的是包装类型做研究,一般在hibernate声明的时候最好不要用基本类型,因为数据库中的null空数据有可能映射为基 ...
- Replication容量和错误日志
gtid排错 set sql_log_bin=off; #人为关闭二进制日志
- linux驱动---等待队列、工作队列、Tasklets【转】
转自:https://blog.csdn.net/ezimu/article/details/54851148 概述: 等待队列.工作队列.Tasklet都是linux驱动很重要的API,下面主要从用 ...