PHP+MySQL是否支持这种类型的伪表联接


Does PHP+MySQL support this style of dummy table join?

我使用一种专有的服务器端语言,该语言位于Oracle数据库之上。使用这种语言,您可以使用伪表来获取填充了数据的现有记录结构,并对连接到该记录结构的记录结构运行查询,就好像它是一个表一样。

这里有一个简单的例子:

    //DECLARE THE RECORD STRUCTURE
    record data_out (
        1 prsnl [*]
            2 person_id = f8
            2 full_name = vc
            2 position = vc
            2 status = vc
            2 last_access_dt_tm = vc
            2 role [*]
                3 role_name = vc
                3 role_id = f8  
    ) with persistscript
    //QUERY PEOPLE
    select into "NL:"
    from person p
    where p.whatever_field = "QUALIFIER"
    detail
        a = a + 1
        stat = alterlist(data_out->prsnl, a)
        data_out->prsnl[a]->person_id = p.person_id
        data_out->prsnl[a]->full_name = p.name_full_formatted
        data_out->prsnl[a]->position = p.position
    with time=10
    //USE A DUMMY TABLE TO PULL IN MORE DATA FOR EACH PERSON
    select into "NL:"
    from (dumt d with seq = size(data_out->prsnl,5))
        ,rnd_role_def rrd
        ,rnd_r_assign_hx rah
    plan d
    join rah
        where rah.team_id = data_in->team_id
        and rah.prsnl_id = data_out->prsnl[d.seq]->person_id
        and rah.handoff_dt_tm > cnvtdatetime(curdate-90,curtime)
    join rrd
        where rrd.role_id = rah.role_id
    order by d.seq, rrd.role_name
    head d.seq
        i = 0
    head rrd.role_name
        i = i + 1
        stat = altlist(data_out->prsnl[d.seq]->role, i)
        data_out->prsnl[d.seq]->role[i]->role_id = rrd.role_id
        data_out->prsnl[d.seq]->role[i]->role_name = rrd.role_name
    with time=10

PHP+MySQL有这样的东西吗?如果是这样的话,可以给我一个链接,提供更多信息或操作方法。谷歌搜索并没有为我找到任何东西——可能是搜索错了关键词。

使用临时表:

CREATE TEMPORARY TABLE temp1

临时表将在当前会话中持续存在。您可以通过正常的CREATE TABLE语法定义临时表的字段:

CREATE TEMPORARY TABLE temp1(
    `id` INT(11) NOT NULL AUTO_INCREMENT,
    `name` VARCHAR(50),
)

或者,您可以创建一个临时表,并允许查询数据定义列:

CREATE TEMPORARY TABLE temp1;
INSERT INTO temp1
  SELECT id, name FROM normal_table

文档

  • MySQL CREATE TABLE语法-http://dev.mysql.com/doc/refman/5.1/en/create-table.html
  • MySQL临时表教程-http://www.tutorialspoint.com/mysql/mysql-temporary-tables.htm

可能有用的三件事:

  1. 内存表(CREATE TABLE mem_t (id (int)) ENGINE=MEMORY;
  2. 临时表格(CREATE TEMPORARY TABLE temp_t (id (int));
  3. 视图

请注意,临时表仅对当前连接可见,而视图和内存表是共享资源(与常规表一样)。

还可以看看SO:上的这些相关问题

  • https://stackoverflow.com/a/2454357/473637
  • 存储过程中的MySQL临时表与内存表

您可以使用临时表和INSERT SELECT语法来实现它,然后删除该表,但这对于性能来说并不是最好的