一、创建数据库表和数据
在进行数据库操作之前,我们需要先创建数据库及相应的数据表。我们假设需要开发一个学生管理系统,其中需要建立一个名为student的数据库表,以存储学生的基本信息。表包含以下字段:
id:主键,自增长。
name:学生姓名,varchar类型,长度为20。
age:学生年龄,int类型。
sex:学生性别,varchar类型,长度为2。
t_score:CET-4考试成绩,int类型。
total_score:学生成绩总和,int类型。
我们可以使用如下的SQL语句创建该数据表:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
CREATE TABLE
student
(
id
int(11) NOT NULL AUTO_INCREMENT COMMENT 自增ID,
name
varchar(20) NOT NULL DEFAULT COMMENT 学生姓名,
age
int(11) NOT NULL DEFAULT 0 COMMENT 学生年龄,
sex
varchar(2) NOT NULL DEFAULT COMMENT 学生性别,
t_score
int(11) NOT NULL DEFAULT 0 COMMENT CET-4考试成绩,
total_score
int(11) NOT NULL DEFAULT 0 COMMENT 学生成绩总和,
PRIMARY KEY (
id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=学生信息表;
我们随机插入一些数据,用于后续测试:
1
2
3
4
5
6
7
8
9
10
11
12
13
INSERT INTO
student
(
name
,
age
,
sex
,
t_score
,
total_score
) VALUES (张三, 20, 男, 550, 750), (李四, 19, 女, 530, 700), (王五, 22, 男, 610, 820), (赵六, 23, 女, 590, 780), (钱七, 21, 男, 500, 730);
二、在ThinkPHP中调用MySQL字段
我们可以使用Db类提供的方法,在ThinkPHP中对数据库进行增、删、改、查等操作。在进行查询操作时,我们需要调用MySQL字段。以下列出了一些常用的调用方式:
1.使用数组方式直接调用:
我们可以使用数组方式来直接调用MySQL字段。查询student表中的id、name、age等字段,可通过以下方式实现:
$studentList = Db::name(student)->field([id, name, age])->select();
$field参数为可选,不传入该参数表示查询所有字段。
2.使用字符串方式调用:
第二种方式为直接使用字符串方式调用MySQL字段,例如:
//查询id,name和age字段
$studentList = Db::name(student)->field(id, name, age)->select();//查询t_score,total_score和总分字段(总分为t_score和total_score相加的结果)
$studentList = Db::name(student)->field(t_score, total_score, (t_score+total_score) as score)->select();在使用字符串方式调用MySQL字段时,我们可以通过as为某字段别名(alias)。
3.使用模型方式调用:
使用模型方式调用时,我们需要先定义模型类。一个名为Student的模型类可以根据student表的结构进行定义
namespace appcommonmodel;
use thinkModel;
class Student extends Model
{1
2
3
//定义表名和主键
protected $table = student;
protected $pk = id;
}
接下来,我们可以使用Student模型类直接操作查询:
//获取所有学生列表信息
$studentList = Student::field([id, name, age])->select();//获取学生姓名和总分
$studentList = Student::field(name, (t_score+total_score) as score)->select();通过模型方式调用MySQL字段可以使我们的代码更加简洁优雅,而且能够有效防止SQL注入问题。
三、在ThinkPHP中进行MySQL字段别名操作
在执行SQL查询语句时,有时我们需要使用列别名作为返回结果的标识。例如,我们要在查询结果中显示学生姓名和比该名学生分数高的其他学生数目,我们可以添加一个别名(alias):
1
$studentList = Db::name(student)->field(name, (SELECT count(*) FROM student as b WHERE b.total_score>s.total_score) as rank)->alias(s)->select();
以上代码通过子查询和alias方法,可以得到人名和排名,其对应的SQL语句为:
1
SELECT name, (SELECT count(*) FROM student as b WHERE b.total_score>s.total_score) as rank FROM student s
在ThinkPHP中,通过使用alias方法,我们可以为MySQL字段设置指定的别名,以达到更高效的查询操作。