一、tp框架数据访问(pdo基础)

public function test()
{
  $n = D("Nation");  //select();find(); //查询   1.$attr = $n->select();//查所有,返回一个关联数组,二维关联数组
  2.$attr = $n->select("n001,n002");//根据参数(主键值)查
  3.$attr = $n->find("n002");//查一条数据,一维数组,参数必须是主键值
 //where //连贯操作
  4.$n->where()->select();//加条件,$n->where()返回一个对象
    $n->where("name=>'汉族' or name='回族'")->select();
  5.table //如果查Nation表以外的数据,用table
    $attr = $n->table("info")->select();
  6.field //指定字段查询(查某几列)
    $attr = $n->field("code")->select();
  7.order //排序
    $attr = $n->order("code desc")->select();
  8.limit //分页
    $a = $n->limit(3,5)->select();//跳过3条数据取5条数据
    $a = $n->limit(3)->select();//取3条数据
  9.page //分页
    $a = $n->page(3,5)->select();//第3页显示5条数据,根据条数来自动分页
  10.group //分组
    $a = $nation->field("Brand,avg(Price)")->group("Brand")->select();
  11.having //分完组加条件
    $a = $nation->field("Brand,avg(Price)")->group("Brand")->having("avg(Price)>40")->select();
  12.distinct //去重
    $a = $nation->field("Brand")->distinct(true)->select();
  13.getField //获取某字段的数据,只能给列名查询,不写where条件,默认给索引最小的字段
    $a = $nation->where("code='n001'")->getField("name");
  14.sum,count,max,min
    $a = $nation->table("car")->sum(Price);
  15.join..on //给索要查询的列都 as 给一个别名显示,别名自定义即可
    $a = $nation->field("Info.code as 'code',Info.name as 'name',Nation.name as '民族'")->join("Info on Info.nation=Nation.code")->select();
  16.cache //数据缓存
  17.query //原生sql语句查询
    $sql = "select * from nation";
    $a = $nation->query($sql);
  18.execute //原生sql语句其他操作 修改
    $sql = "update Nation set name='满族' where code='n001'";
    $a = $nation->execute($sql);   var_dump($a);
}

二、数据添加

<?php
namespace Zuoye\Controller;
use Think\Controller;
class MainController extends Controller
{
public function test()
{
//造模型对象
$n = D("Nation"); //使用数组的方式添加
$attr = array("Code"=>"n100","Name"=>"汉族");
$n->add($attr); //使用AR的方式
$n->Code="n099";
$n->Name="回族";
$n->add(); }
public function _empty()
{
echo "连接失败!";
}
}

三、通过地址栏传参数,如:Main/canshu/id/5,方法来接收使用

<?php
namespace Lianxi\Controller;
use Think\Controller;
class MainController extends Controller
{
//通过地址栏传参数,如:Main/canshu/id/5,方法来接收使用
public function canshu($id)
{
//方法一
//echo $_GET["id"];
//方法二:canshu($id)
echo $id;//如果给$id赋值canshu($id=0)时,地址栏不给参数也不会报错
}
}

四、自动收集表单(功能强大,把表单里面的内容用create方法快速收集)

Application/Lianxi/controller/MainController.class.php

<?php
namespace Lianxi\Controller;
use Think\Controller;
class MainController extends Controller
{
public function Biaodan()
{
//实现两个逻辑
//1.显示添加页面2.往数据库添加数据
if(empty($_POST))
{
$this->show();
}
else
{
$n = D("Nation");
$n->create();//自动收集表单,前提是必须有post数据,如果post为空,走if;html页面中input里面的name一定要对应数据库表的的列名,大小写敏感
$z = $n->add();
if($z)
{
//跳转方法一
//$this->success("添加成功","Biaodan",5);//5是跳转时间,间隔5秒
//跳转方法二
$this->redirect('Biaodan',array(),5,"页面跳转中...");//array('id'=>2),跳转页面的同时可以传参数,关联
}
else
{
$this->error("添加失败!");//一个参数就可以,error失败默认返回前一个页面
}
}
}
}

Application/Lianxi/view/Main/Biaodan.html

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<form action="__SELF__" method="post">
<div>代号:<input type="text" name="Code" /></div>
<div>名称:<input type="text" name="Name" /></div>
<input type="submit" value="添加" />
</form>
</body>
</html>

1.跳转页面失败后如何把错误信息去掉的问题:

2.在表单<form>里面的action指向哪里的问题:指向__SELF__或者__ACTION__

先var_dump(get_defined_constants(true));显示出系统常量,找到__SELF__和__ACTION__;

__SELF和__ACTION__的区别:__SELF__访问的是自身,就是浏览器访问的地址,如:localhost/tp/index.php/Home/Main/Biaodan/code/10(code和10是随意传的参数),__ACTION__只能访问到Biaodan(方法)这里

数据库访问CRUD;__SELF__和__ACTION__的区别;自动收集表单:$n->create();的更多相关文章

  1. ThinkPHP数据库访问CRUD;__SELF__和__ACTION__的区别;自动收集表单:$n->create();

    一.tp框架数据访问(pdo基础) public function test() { $n = D("Nation"); //select();find(); //查询 1.$at ...

  2. 基于ASP.NET WEB API实现分布式数据访问中间层(提供对数据库的CRUD)

    一些小的C/S项目(winform.WPF等),因需要访问操作数据库,但又不能把DB连接配置在客户端上,原因有很多,可能是DB连接无法直接访问,或客户端不想安装各种DB访问组件,或DB连接不想暴露在客 ...

  3. 适用于app.config与web.config的ConfigUtil读写工具类 基于MongoDb官方C#驱动封装MongoDbCsharpHelper类(CRUD类) 基于ASP.NET WEB API实现分布式数据访问中间层(提供对数据库的CRUD) C# 实现AOP 的几种常见方式

    适用于app.config与web.config的ConfigUtil读写工具类   之前文章:<两种读写配置文件的方案(app.config与web.config通用)>,现在重新整理一 ...

  4. 我也来写:数据库访问类DBHelper

    一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...

  5. 我也来写:数据库访问类DBHelper(转)

    一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...

  6. Oracle数据库名、实例名、数据库域名、全局数据库名、服务名之间的区别

    数据库名.实例名.数据库域名.全局数据库名.服务名 这是几个令很多初学者容易混淆的概念.相信很多初学者都与我一样被标题上这些个概念搞得一头雾水.我们现在就来把它们弄个明白. 一.数据库名 什么是数据库 ...

  7. 使用Repository模式构建数据库访问层

    使用Repository模式构建数据库访问层 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程[二]——使用Repository模式构建数据库访问层 系列导航地址http:// ...

  8. Spring Boot使用Spring Data Jpa对MySQL数据库进行CRUD操作

    只需两步!Eclipse+Maven快速构建第一个Spring Boot项目 构建了第一个Spring Boot项目. Spring Boot连接MySQL数据库 连接了MySQL数据库. 本文在之前 ...

  9. mybatis与数据库访问相关的配置以及设计

    mybatis与数据库访问相关的配置以及设计 mybatis不管如何NB,总是要与数据库进行打交道.通过提问的方式,逐步深入 我们常用的MyBatis配置中哪些是与数据库相关? 数据源配置: < ...

随机推荐

  1. Java批量文件打包下载

    经常遇到选择多个文件进行批量下载的情况,可以先将选择的所有的文件生成一个zip文件,然后再下载,该zip文件,即可实现批量下载,但是在打包过程中,常常也会出现下载过来的zip文件中里面有乱码的文件名, ...

  2. .NET 多线程

    多线程 在一个程序中,这些独立运行的程序片断叫作“线程”(Thread),利用它编程的概念就叫作“多线程处理”.多线程处理一个常见的例子就是用户界面.利用线程,用户可按下一个按钮,然后程序会立即作出响 ...

  3. LNMP平台搭建---PHP安装篇

    在前面三篇中,我们安装了Linux系统.Web服务器Nginx.MySQL数据库服务器,这篇就来将搭建动态网站的最后一步:PHP安装. Nginx服务器只能响应静态资源请求,对于动态资源请求就不行了, ...

  4. 如何使用Android JetPlayer类

    在Android中,还提供了对Jet播放的支持,Jet是由OHA联盟成员SONiVOX开发的一个交互音乐引擎.其包括两部分:JET播放器和JET引擎.JET常用于控制游戏的声音特效,采用MIDI(Mu ...

  5. shell不能执行su 后的脚本

    问题:在shell脚本中执行“su – 用户名”后,脚本终止执行,并且切换到su 中指定用户名的交互式界面  现象:我在root中执行一个脚本,但是其中的一些命令或脚本必须用oracle用户来执行., ...

  6. 【CentOS】磁盘管理与vim编译器

    一.查看硬盘或目录容量 1.df  [-hmkiT] -h  查看系统磁盘使用情况 -m  使用MBytes显示结果 -k  使用KBytes显示结果 -i  查看inode -T  查看Type 2 ...

  7. 修改nignx报错Nginx [emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)

    Nginx [emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use) 这个错误是修改了nginx的配置时出现,表名80端口被程 ...

  8. ArrayList数组列表

    ArrayList数组列表 Collection接口和List接口的区别 List接口扩充了Collection接口,添加了索引相关的方法. code example Object get(int i ...

  9. 理解margin

    margin可以改变容器的尺寸 //元素尺寸分为可视尺寸,占据尺寸 margin与可视尺寸 1.适用于没有设定width/height的普通block水平元素 2.只适用于水平方向的尺寸 应用:一侧定 ...

  10. 用PS去除图片中文字的6个方法

    转自:http://www.u148.net/article/486.html 1.使用仿制图章工具去除文字. 这是比较常用的方法.具体的操作是,选取仿制图章工具,按住Alt键,在无文字区域点击相似的 ...