0

我正在尝试从我的查询中创建视图,这样:

CREATE VIEW v_test
(
OS_ID,
OS_IMIE,
KO_SYMBOL,
OS_NAZWISKO,
OS_SYGNATURA_APS,
UP_DATA_WAZNOSCI_SZKOLENIA,
UP_WAZNOSC_SZKOLENIA_DNI,
UP_DATA_SZKOLENIA,
KT_ID,
KT_DZIEDZINA
)
AS
SELECT
a.OS_ID,
a.OS_IMIE,
a.KO_SYMBOL,
a.OS_NAZWISKO,
a.OS_SYGNATURA_APS,
b.UP_DATA_WAZNOSCI_SZKOLENIA,
b.UP_WAZNOSC_SZKOLENIA_DNI,
b.UP_DATA_SZKOLENIA,
b.KT_ID,
b.KT_DZIEDZINA

FROM (SELECT
      v_ra_osoby_uprawnione.OS_ID,
      v_ra_osoby_uprawnione.KO_SYMBOL,
      v_ra_osoby_uprawnione.OS_NAZWISKO,
      v_ra_osoby_uprawnione.OS_IMIE,
      v_ra_osoby_uprawnione.OS_SYGNATURA_APS,
      v_ra_osoby_uprawnione.OS_EMAIL,
      v_ra_osoby_uprawnione.OS_UZYTKOWNIK
      FROM v_ra_osoby_uprawnione AS v_ra_osoby_uprawnione) AS a INNER JOIN (SELECT
      v_ra_uprawnienia.UP_ID,
      v_ra_uprawnienia.OS_ID,
      v_ra_uprawnienia.UP_NR_POSWIADCZENIA,
      v_ra_uprawnienia.UP_DATA_WAZNOSCI_KLAUZULI,
      v_ra_uprawnienia.UP_DATA_WYDANIA_POSWIADCZENIA,
      v_ra_uprawnienia.UP_NR_ZASWIADCZENIA_O_SZKOLENIU,
      v_ra_uprawnienia.UP_DATA_SZKOLENIA,
      v_ra_uprawnienia.UP_DATA_WAZNOSCI_SZKOLENIA,
      v_ra_uprawnienia.UP_DATA_WAZNOSCI_SZKOLENIA - CURDATE() as UP_WAZNOSC_SZKOLENIA_DNI,
      v_ra_uprawnienia.KT_ETYKIETA,
      v_ra_uprawnienia.KT_DZIEDZINA,
      v_ra_uprawnienia.KT_ID,
      v_ra_uprawnienia.SCISLE_TAJNE,
      v_ra_uprawnienia.TAJNE,
      v_ra_uprawnienia.POUFNE,
      v_ra_uprawnienia.ZASTRZEZONE
      FROM v_ra_uprawnienia AS v_ra_uprawnienia) AS b ON b.OS_ID = a.OS_ID

但是mysql不允许创建视图,错误码是:SQL Error: View's SELECT contains a subquery in the FROM clause

我想避免为每个子查询创建视图。在这种情况下,是否可以通过将我的查询重写为没有子查询的等价物来创建单个视图?

4

2 回答 2

1

在这种情况下,是否可以通过将我的查询重写为没有子查询的等价物来创建单个视图?

是的:

CREATE VIEW v_test AS
SELECT a.OS_ID,
       a.OS_IMIE,
       a.KO_SYMBOL,
       a.OS_NAZWISKO,
       a.OS_SYGNATURA_APS,
       b.UP_DATA_WAZNOSCI_SZKOLENIA,
       b.UP_DATA_WAZNOSCI_SZKOLENIA - CURDATE() AS UP_WAZNOSC_SZKOLENIA_DNI,
       b.UP_DATA_SZKOLENIA,
       b.KT_ID,
       b.KT_DZIEDZINA
FROM   v_ra_osoby_uprawnione a JOIN v_ra_uprawnienia b USING (OS_ID)
于 2012-09-13T12:21:03.970 回答
1

为什么要使用子查询?

您的查询仅适用于联接

SELECT
    a.OS_ID,
    a.OS_IMIE,
    a.KO_SYMBOL,
    a.OS_NAZWISKO,
    a.OS_SYGNATURA_APS,
    b.UP_DATA_WAZNOSCI_SZKOLENIA,
    b.UP_WAZNOSC_SZKOLENIA_DNI - CURDATE() as UP_WAZNOSC_SZKOLENIA_DNI
    b.UP_DATA_SZKOLENIA,
    b.KT_ID,
    b.KT_DZIEDZINA

    FROM v_ra_osoby_uprawnione AS a 
    INNER JOIN v_ra_uprawnienia AS b ON b.OS_ID = a.OS_ID

尝试用这个创建视图

于 2012-09-13T12:23:33.123 回答