初识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 ...
随机推荐
- matplotlib交互模式与pacharm单独Figure设置
matplotlib交互模式与pacharm单独Figure设置 觉得有用的话,欢迎一起讨论相互学习~Follow Me Matpotlib交互模式 在运行python程序时有时候需要生成以下的 动态 ...
- html <label>标签
label元素在呈现上没有特殊效果,但为鼠标用户增进了可用性. 如果在label元素内点击文本,就会触发表单控件. 也就是说,当用户选择该标签时,浏览器就会自动将焦点转到和标签相关的表单控件上. &l ...
- SpringBoot入门Demo(Hello Word Boot)
Spring Boot 是由Pivotal团队提供的全新框架,其设计目的是用来简化新的Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置. ...
- Spring RedisTemplate操作-事务操作(9)
@Autowired @Qualifier("redisTemplate") private RedisTemplate<String, String> stringr ...
- 使用 git 托管代码
1. 下载安装好 git 客户端 2. 找一个家代码托管平台 我用 coding.net,注册个账号,建一个空项目 然后打开安装好的 git bash 客户端,使用 git clone 命令克隆下远程 ...
- mybatis mapper接口开发dao层
本文将探讨使用 mapper接口,以及 pojo 包装类进行 dao 层基本开发 mybatis dao 层开发只写 mapper 接口 其中需要 开发的接口实现一些开发规范 1. UserMappe ...
- vue注册全局属性
例:统一引用getSpiderToken方法 main.js中相关代码 import { getSpiderToken } from '../static/js/storage' Vue.protot ...
- 深入分析Java Web技术内幕
深入web请求过程 发起一个http请求的过程就是建立一个socket通信的过程 HTTPClient是一个开源的实现了http请求的工具包 深入分析java I/O的工作机制 深入分析java We ...
- 使用phpstorm+wamp实现php代码实时调试审计
转载自:https://www.bugbank.cn/q/article/5853afaffc0bf4f010ee6ac3.html php调试有N多好用的工具,最近研究到phpstorm配合wamp ...
- House Robber I & II & III
House Robber You are a professional robber planning to rob houses along a street. Each house has a c ...