配置好数据库连接以后,你可以使用 database 来执行查询。 QueryPHP 提供了 select 、 update 、 insert 、 delete 和 statement 的查询方法。
# 查询数据
从数据库获取列表数据,用于页面渲染。
~~~
$arrData = database::query('select * from q_test where id=?',[44]);
var_dump($arrData);
~~~
# 执行 sql
执行一般的 sql,不返回记录数据。
~~~
$intLastID = database::execute('insert into q_test (name, value) values (?, ?)',['小鸭子','喜欢游泳']);
var_dump($intLastID);
~~~
# 查询数据 select
使用 select 方法进行数据库的原生查询,只能运行 select 开头的。
~~~
<?php
namespace home\controller;
use Q\mvc\controller;
use Q\database\database;
class index extends controller {
/**
* 默认方法
*/
public function index() {
$arrData = database::select('select * from test where id = ?', [4] );
print_r($arrData);
}
}
~~~
注意:第二个为参数绑定,系统采用 Pdo 默认提供的参数过滤,可以防止 SQL 攻击。
# 命名绑定 bind
除了使用 ? 来表示参数绑定外,你也可以使用命名绑定:
~~~
$arrData = database::select('select * from q_test where id = :id', ['id' => 4]) );
print_r($arrData);
~~~
# 写入数据 insert
使用 insert 方法进行数据库的原生写入,只能运行 insert 开头的。。
~~~
$intLastID = database::insert('insert into q_test (name, value) values (?, ?)', ['小鸭子', '喜欢游泳']);
var_dump($intLastID);
~~~
# 更新数据 update
使用 update 方法进行数据库的原生更新,只能运行 update 开头的。。
~~~
$intNumRow = database::update('update q_test set name = "2342342342" where id = ?', [3]);
var_dump($intNumRow);
~~~
# 删除数据 delete
使用 delete 方法进行数据库的原生删除,只能运行 delete 开头的。。
~~~
$intNumRow = database::delete('delete from q_test where id = ?', [3]);
var_dump($intNumRow);
~~~
# 其它声明执行 stagement
有些数据库没有返回值, 可以使用 statement 方法,只能运行无返回值的。
~~~
database::statement('drop table q_test');
~~~
- 关于 QueryPHP
- 获取 QueryPHP
- 环境要求
- 许可协议 Free
- 执行流程 MVC
- 命名规范 $sName
- 目录结构 DIR
- 单一入口 index.php
- 响应客户端请求 URL
- 命名空间与自动载入 Autoload
- 路由
- 路由导入
- 批量导入
- 参数正则
- 分组定义
- 路由绑定
- 路由域名
- 分层控制器
- 默认和初始化APP
- 默认控制器和方法
- url 模式
- url 生成
- url 伪静态
- url 重写
- url 重定向
- 控制器绑定
- 方法器分层
- 控制器 __init
- 控制器方法交互
- 模板引擎语法
- C变量输出 $sName
- C变量支持函数和方法 $sName|trim
- C快捷输出 ~
- C标签简化 Css & Javascript
- C默认值 eq 三元运算符
- C变量运算符 +-
- 变量递增递减 ++--
- C循环数据 list
- N变量赋值 assign
- N循环数据 list
- N循环数据高级版 lists
- C循环数据 while
- N循环数据 while
- C循环数据 for
- N循环数据 for
- C条件判断 if
- N条件判断 if
- 标签嵌套无限层级
- N循环流程 break & continue
- N使用 PHP 代码
- N包含子模板 include
- J模板引擎 intro
- J条件判断 if
- J循环数据 each
- J变量 & 表达式
- J变量支持函数和方法 hello|test
- J默认值 eq 三元运算符
- J框架前端组件 jquery.queryphp.js
- J前端 CSS 规范
- J前端 JS 规范
- 保护标签自身 tagself
- 数据库
- 数据库配置
- 执行原生 sql 语句
- 数据库事务
- 数据库构造器 prefix
- 数据库构造器 table
- 数据库构造器 forceIndex
- 数据库构造器 where
- 数据库构造器 bind
- 数据库构造器 join
- 数据库构造器 union
- 数据库构造器 orderBy
- 数据库构造器 groupBy
- 数据库构造器 having
- 数据库构造器 distinct
- 数据库构造器 aggregate
- 数据库构造器 limit
- 数据库构造器 forUpdate
- 数据库构造器 columns
- 数据库构造器 reset
- 数据库集合查询
- 数据库查询数据 get
- 数据库查询多条数据 getAll
- 数据库查询单条数据 getOne
- 数据库查询聚合查询 aggregate
- 数据库写入数据 insert
- 数据库写入数据 insertAll
- 配置
- 配置格式
- 惯性配置
- 配置文件
- 读取配置
- 设置配置
- 删除配置
- 日志
- 日志配置参数
- 日志路径
- 日志过滤器
- 日志处理器
- 缓存
- 缓存配置参数
- 缓存路径
- 缓存指定时间
- COOKIE
- COOKIE 配置参数
- 开发调试
- 页面 trace