yii常用操作数据

谁借莪1个温暖的怀抱¢ 2021-12-19 19:04 298阅读 0赞

yii常用操作数据.php

  1. <?php
  2. defined('YII_DEBUG') or define('YII_DEBUG', true); //当在调试模式下,应用会保留更多日志信息,如果抛出异常,会显示详细的错误调用堆栈。因此,调试模式主要适合在开发阶段使用,YII_DEBUG 默认值为 false。
  3. return $this->render('list'); //加载视图模板,一定要return 否则会空白
  4. $this->render('_overview'); //在视图模板中,可以通过这种方式加载视图模板
  5. //#############################请求#######################
  6. $request = Yii::$app->request;
  7. $get = $request->get(); // 等价于: $get = $_GET;
  8. $id = $request->get('id'); // 等价于: $id = isset($_GET['id']) ? $_GET['id'] : null;
  9. $id = $request->get('id', 1); // 等价于: $id = isset($_GET['id']) ? $_GET['id'] : 1;
  10. $post = $request->post(); // 等价于: $post = $_POST;
  11. $name = $request->post('name'); // 等价于: $name = isset($_POST['name']) ? $_POST['name'] : null;
  12. $name = $request->post('name', ''); // 等价于: $name = isset($_POST['name']) ? $_POST['name'] : '';
  13. //#############################请求方式#######################
  14. $request = Yii::$app->request;
  15. if ($request->isAjax) { /* 该请求是一个 AJAX 请求 */ }
  16. if ($request->isGet) { /* 请求方法是 GET */ }
  17. if ($request->isPost) { /* 请求方法是 POST */ }
  18. if ($request->isPut) { /* 请求方法是 PUT */ }
  19. //#############################请求类属性#######################
  20. Yii::$app->request->url; //结果:/admin/index.php/product?id=100, 此URL不包括host info部分。
  21. Yii::$app->request->absoluteUrl; //结果:http://www.phpxs.com/post/index.php/product?id=100, 包含host infode的整个URL。
  22. Yii::$app->request->hostInfo; //结果:http://www.phpxs.com, 只有host info部分。
  23. Yii::$app->request->pathInfo; //结果:/product, 这个是入口脚本之后,问号之前(查询字符串)的部分。
  24. Yii::$app->request->queryString; //结果:id=100,问号之后的部分。
  25. Yii::$app->request->baseUrl; //结果:/admin, host info之后, 入口脚本之前的部分。
  26. Yii::$app->request->scriptUrl; //结果:/admin/index.php, 没有path info和查询字符串部分。
  27. Yii::$app->request->serverName; //结果:example.com, URL中的host name。
  28. Yii::$app->request->serverPort; //结果:80, 这是web服务中使用的端口。
  29. Yii::$app->request->userAgent; //结果:返回 User-Agent 头
  30. Yii::$app->request->contentType; //结果:返回 Content-Type 头的值, Content-Type 是请求体中MIME类型数据。
  31. Yii::$app->request->acceptableContentTypes; //结果:返回用户可接受的内容MIME类型。 返回的类型是按照他们的质量得分来排序的。得分最高的类型将被最先返回。
  32. Yii::$app->request->acceptableLanguages; //结果:返回用户可接受的语言。 返回的语言是按照他们的偏好层次来排序的。第一个参数代表最优先的语言。
  33. Yii::$app->request->getPreferredLanguage(); //结果:这个方法通过 yiiwebRequest::acceptableLanguages 在你的应用中所支持的语言列表里进行比较筛选,返回最适合的语言。
  34. //#############################客户端信息#######################
  35. Yii::$app->request->userHost;
  36. Yii::$app->request->userIP;
  37. #############################HTTP头部#######################
  38. $headers = Yii::$app->response->headers;
  39. $headers->add('Pragma', 'no-cache'); // 增加一个 Pragma 头,已存在的Pragma 头不会被覆盖。
  40. $headers->set('Pragma', 'no-cache'); // 设置一个Pragma 头. 任何已存在的Pragma 头都会被丢弃
  41. $values = $headers->remove('Pragma'); // 删除Pragma 头并返回删除的Pragma 头的值到数组
  42. //#############################文件下载#######################
  43. yiiwebResponse::sendFile(); //发送一个已存在的文件到客户端
  44. yiiwebResponse::sendContentAsFile(); //发送一个文本字符串作为文件到客户端
  45. yiiwebResponse::sendStreamAsFile(); //发送一个已存在的文件流作为文件到客户端
  46. public function actionDownload(){
  47. return Yii::$app->response->sendFile('path/to/file.txt');
  48. }
  49. //#############################301跳转########################
  50. Yii::$app->response->redirect('http://example.com/new', 301)->send();
  51. //#############################状态码########################
  52. Yii::$app->response->statusCode = 200;
  53. //#############################session使用########################
  54. $session = Yii::$app->session;
  55. if ($session->isActive) // 检查session是否开启
  56. $session->open(); // 开启session
  57. $session->close(); // 关闭session
  58. $session->destroy(); // 销毁session中所有已注册的数据
  59. //#########################cookie的使用#############
  60. $cookies = Yii::$app->request->cookies;
  61. $language = $cookies->getValue('language', 'en'); // 获取名为 "language" cookie 的值,如果不存在,返回默认值"en"
  62. // 另一种方式获取名为 "language" cookie 的值
  63. if (($cookie = $cookies->get('language')) !== null) {
  64. $language = $cookie->value;
  65. }
  66. // 可将 $cookies当作数组使用
  67. if (isset($cookies['language'])) {
  68. $language = $cookies['language']->value;
  69. }
  70. // 在要发送的响应中添加一个新的cookie
  71. $cookies->add(new yiiwebCookie([
  72. 'name' => 'language',
  73. 'value' => 'zh-CN',
  74. ]));
  75. // 判断是否存在名为"language" 的 cookie
  76. if ($cookies->has('language'))
  77. if (isset($cookies['language'])) ;
  78. //#####################Yii2.0 对数据库 查询的一些简单的操作 #####################
  79. class UserModel extends yiidbActiveRecord{
  80. public function test(){
  81. self::find()->all(); //此方法返回所有数据;
  82. self::findOne($id); //此方法返回 主键 id=1 的一条数据(举个例子);
  83. self::find()->where(['name' => '小伙儿'])->one(); //此方法返回 ['name' => '小伙儿'] 的一条数据;
  84. self::find()->where(['name' => '小伙儿'])->all(); //此方法返回 ['name' => '小伙儿'] 的所有数据;
  85. self::find()->orderBy('id DESC')->all(); //此方法是排序查询;
  86. self::findBySql('SELECT * FROM user')->all(); //此方法是用 sql 语句查询 user 表里面的所有数据;
  87. self::findBySql('SELECT * FROM user')->one(); //此方法是用 sql 语句查询 user 表里面的一条数据;
  88. self::find()->andWhere(['sex' => '男', 'age' => '24'])->count('id'); //统计符合条件的总条数;
  89. self::find()->one(); //此方法返回一条数据;
  90. self::find()->all(); //此方法返回所有数据;
  91. self::find()->count(); //此方法返回记录的数量;
  92. self::find()->average('age'); //此方法返回指定列的平均值;
  93. self::find()->min('age'); //此方法返回指定列的最小值 ;
  94. self::find()->max('age'); //此方法返回指定列的最大值 ;
  95. self::find()->scalar(); //此方法返回值的第一行第一列的查询结果;
  96. self::find()->column(); //此方法返回查询结果中的第一列的值;
  97. self::find()->exists(); //此方法返回一个值指示是否包含查询结果的数据行;
  98. self::find()->batch(10); //每次取 10 条数据
  99. self::find()->each(10); //每次取 10 条数据, 迭代查询
  100. }
  101. }

转载于:https://www.cnblogs.com/lovellll/p/10200490.html

发表评论

表情:
评论列表 (有 0 条评论,298人围观)

还没有评论,来说两句吧...

相关阅读

    相关 数据分析:SQL操作

    摘要:SQL作为工作常用的基本技能,不论是算法还是后端都得从数据库取数据,这项基本技能简单通用但一定得熟,总结一些有特点的SQL操作如下。 (1)SQL语句的语法顺序

    相关 yii2小技巧

    arrayHelper::map()这个方法可以将一个数组拆成一个键-值对映射的多维数组或对象数组。在下拉菜单中经常可以使用到 $array = [