tp5数据库操作 Db类
一、链接数据库
1.配置文件定义 application\database.php
注意:数据表前缀更改,在文件的prefix选项

2.类定义

二、数据库的基本使用
namespace app\demo\controller;
use think\Db;
class Ceshi{
public function sql(){
//1.使用系统Db类
$data = Db::table('ceshi')->select();
//2.使用sql语句
$data = Db::query('select * from ceshi');
dump($data);
}
}
三、数据查询
1.table方式
查所有 Db::table('ceshi')->select();
查一条 Db::table('ceshi')->find();
2.name方式
查所有 Db::name('ceshi')->select();
查一条 Db::name('ceshi')->find();
区别:name方式会在表名前自动加设置的前缀
3.助手函数
db('ceshi')->select();
db('ceshi')->find();
注意:助手函数同样会加前缀
四、条件查询
注意:条件的顺序可以随意,如6
1.范围查询
$data = db('ceshi')
->where('id','>','1')
->where('id','<','3')
->select();
dump($data);
2.多条件查询(并且 where)
$data = db('ceshi')
->where('id','>','1')
->where('pin','=','lisi')
->select();
dump($data);
3.多条件查询(或者 whereOr)
$data = db('ceshi')
->where('id','=','1')
->whereOr('id','=','3')
->select();
dump($data);
4.模糊查询
$data = db('ceshi')
->where('id','>','1')
->where('pin','like','li%')
->select();
dump($data);
5.limit截取查询
$data = db('ceshi')
->where('id','>','0')
//跳过几条取几条,一个参数为显示几条
->limit(1,2)
->select();
dump($data);
6.order排序
$data = db('ceshi')
->where('id','>','0')
//跳过几条取几条,一个参数为显示几条
->limit(1,2)
->order('id','desc')
->select();
dump($data);
7.field查询字段
$data = db('ceshi')
->where('id','>','0')
//查询的字段名
->field(['id','pin'])
// //或者,第二种写法
// ->field("id,pin")
->select();
dump($data);
8.更改字段名
$data = db('ceshi')
->where('id','>','0')
//将显示的字段名id更改为uid
->field(['id'=>'uid','pin'])
// //或者,第二种写法
// ->field("id uid,pin")
->select();
dump($data);
9.系统函数
$data = db('ceshi')
->where('id','>','0')
//将显示的字段名id更改为uid
->field(['count(*)'=>'num','pin'])
// //或者,第二种写法
// ->field("count(*) as num,pin")
->select();
10.排除字段
$data = db('ceshi')
->where('id','>','0')
//不显示name字段
->field(['name'],true)
// //或者,第二种写法
// ->field("name",true)
->select();
11.分页查询
$data = db('ceshi')
->where('id','>','0')
//显示,第几页的,几条
->page("2,2")
->select();
12.group 分组查询
$data = db('ceshi')
->where('id','>','0')
->group('id')
->select();
13.having 过滤查询
->having("id > 2")
14.多表联查
$data = db('ceshi')
//查找的字段
->field('ceshi.*,ceshi2.name')
//连表2,on后面的条件,第三参数可不写,left和right为左连接,右连接
->join('ceshi2','ceshi1.pin = ceshi2.pin','left')
->select();
15.表名起别名 (表名后 空格 别名)
16.参数绑定
$data = db('ceshi')
//占位
->where('id',':id')
//参数绑定
->bind(["id"=>"1"])
->select();
17.数据统计
->sum('字段名')
可选sum max min avg count等
五、数据增加
$sql = [
['id'=>'5','pin'=>'zhaoliu','name'=>'赵六'],
['id'=>'6','pin'=>'zhaoliu','name'=>'赵六']
]
$data = db('ceshi')
->insertAll($sql);
若插入一条,则$sql 写一维数组, insertAll改为insert
注意:插入数据的字段名必须和数据库一致
六、数据更新
$data = db('ceshi')
//等号可不写
->where('id',4)
//更改的数据
->update(['name'=>'a','pin'=>'a']);
自增
->setInc('字段名')
自减
->setDec('字段名',每次减几)
七、删除数据(四种方式,不带字段名的为id主键的值)
->where('id',1)->delete()
->where("id in(1,2,3)")->delete()
->delete([1,2,3])
->where("id>2 and id <4")->delete()
tp5数据库操作 Db类的更多相关文章
- Discuz!数据库操作DB类和C::t类介绍
类定义文件 DB类: 文件\source\class\class_core.php class DB extends discuz_database {} discuz_database类定义 文件\ ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 五 Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 【转载】微软官方提供的Sqlserver数据库操作帮助类SQLHelper类
在.NET平台中,C#语言一般使用ADO.NET组件来操作Sqlserver数据库,通过ADO.NET组件可以实现连接数据库.查询数据集.执行SQL语句以及关闭数据库连接等操作,为此网上有很多开发者自 ...
- nodejs操作mongodb数据库封装DB类
这个DB类也算是我经历了3个实际项目应用的,现分享出来,有需要的请借鉴批评. 上面的注释都挺详细的,我使用到了nodejs的插件mongoose,用mongoose操作mongodb其实蛮方便的. 关 ...
- nodejs mongodb 数据库封装DB类 -转
使用到了nodejs的插件mongoose,用mongoose操作mongodb其实蛮方便的. 关于mongoose的安装就是 npm install -g mongoose 这个DB类的数据库配置是 ...
- OSChina底层数据库操作的类(QueryHelper)源代码
OSChina 使用的是 dbutils 这个JDBC的封装类库来进行数据库操作. 而 QueryHelper 则是在 dbutils 的基础上进行一级简单的封装,提供一些经常使用的数据库操作方法和对 ...
- 封装类似thinkphp连贯操作数据库的Db类(简单版)。
<?php header("Content-Type:text/html;charset=utf-8"); /** *php操作mysql的工具类 */ class Db{ ...
- ADO.NET数据库操作助手类
SQL语句操作增删查改助手类 using System; using System.Collections.Generic; using System.Configuration; using Sys ...
随机推荐
- SQL Server-语句类别、数据库范式、系统数据库组成
前言 终于等到这一天,我要开始重新系统学习数据库了,关于数据库这块,不出意外的话,每天会定时更新一篇且内容不会包含太多,简短的内容,深入的理解,Always to review the basic ...
- SPL类
用途:对类,方法,属性,参数的提取生成文档:自动加载插件 实列化类同于new:$ref = new ReflectionClass($classname);$class = $ref->newI ...
- 分层利器 facade
Facade(外观)模式为子系统中的各类(或结构与方法)提供一个简明一致的界面,隐藏子系统的复杂性,使子系统更加容易使用.
- form 表单的另类触发方式:报错触发
在用form表单提交的时候,遇到一个问题:表单未验证完,表单就提前提交了. 然后通过断点调试,发现form提交会因为函数报错提前提交. 即如果你的form提交过程中,没有执行到return true之 ...
- Robot Framework(三)创建测试用例
2.2.1测试用例语法 基本语法 测试用例由关键字在测试用例表中构建.关键字可以从测试库或资源文件导入,也可以在测试用例文件本身的关键字表中创建. 测试用例表中的第一列包含测试用例名称.测试用例从包含 ...
- form表单提交三种方式,demo实例详解
第一种:使用type=submit 可以直接提交 <html> <head> <title>submit直接提交</title> </head& ...
- 团体程序设计天梯赛-练习集-L1-029. 是不是太胖了
L1-029. 是不是太胖了 据说一个人的标准体重应该是其身高(单位:厘米)减去100.再乘以0.9所得到的公斤数.已知市斤是公斤的两倍.现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自 ...
- iOS runLoop 原理多线程 总结 NSTimer优化
可以理解为字面意思:Run 表示运行,Loop 表示循环.结合在一起就是运行的循环的意思.哈哈,我更愿意翻译为『跑圈』.直观理解就像是不停的跑圈. RunLoop 实际上是一个对象,这个对象在循环中用 ...
- redis 安装成功后外部服务器链接不上
1.reids服务器的6379端口telnet不通 2. 查看reids进程和端口,都是存在的.只是ip地址是127.0.0.1而不是0.0.0.0,只是本机能使用 3.查找redis的配置文件red ...
- [POJ2104] K – th Number (可持久化线段树 主席树)
题目背景 这是个非常经典的主席树入门题--静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 输入输 ...