Szybki start: nawiązywanie połączeń i wykonywanie zapytań dotyczących danych w usłudze Azure Database for PostgreSQL — serwer elastyczny przy użyciu języka PHP
DOTYCZY: Azure Database for PostgreSQL — serwer elastyczny
Ten przewodnik Szybki start przedstawia nawiązywanie połączenia z usługą Azure Database for PostgreSQL przy użyciu aplikacji PHP . Pokazano w nim, jak używać instrukcji języka SQL w celu wysyłania zapytań o dane oraz wstawiania, aktualizowania i usuwania danych w bazie danych. W krokach w tym artykule założono, że wiesz już, jak programować przy użyciu języka PHP i dopiero zaczynasz pracę z usługą Azure Database for PostgreSQL.
Wymagania wstępne
Ten przewodnik Szybki start używa zasobów utworzonych w temacie Tworzenie wystąpienia usługi Azure Database for PostgreSQL — serwer elastyczny jako punkt wyjścia.
Zainstaluj środowisko PHP.
Zainstaluj język PHP na serwerze lub utwórz aplikację internetową platformy Azure zawierającą język PHP.
Windows
- Pobierz wersję języka PHP 7.1.4 nieprzeczytaną (x64)
- Zainstaluj język PHP i zapoznaj się z podręcznikiem języka PHP w celu przeprowadzenia dalszej konfiguracji.
- Kod używa klasy pgsql (ext/php_pgsql.dll) uwzględnionej w instalacji języka PHP.
- Włącz rozszerzenie pgsql, edytując plik konfiguracji php.ini, który zazwyczaj znajduje się w folderze
C:\Program Files\PHP\v7.1\php.ini
. Plik konfiguracji powinien zawierać wiersz z tekstemextension=php_pgsql.so
. Jeśli nie jest wyświetlany, dodaj tekst i zapisz plik. Jeśli tekst jest obecny, ale skomentowany z prefiksem średnika, usuń komentarz tekstu, usuwając średnik.
Linux (Ubuntu)
- Pobierz wersję języka PHP 7.1.4 nieprzeczytaną (x64)
- Zainstaluj język PHP i zapoznaj się z podręcznikiem języka PHP w celu przeprowadzenia dalszej konfiguracji.
- Kod używa klasy pgsql (php_pgsql.so). Zainstaluj ją, uruchamiając element
sudo apt-get install php-pgsql
. - Włącz rozszerzenie pgsql, edytując plik konfiguracji
/etc/php/7.0/mods-available/pgsql.ini
. Plik konfiguracji powinien zawierać wiersz z tekstemextension=php_pgsql.so
. Jeśli nie jest wyświetlany, dodaj tekst i zapisz plik. Jeśli tekst jest obecny, ale skomentowany z prefiksem średnika, usuń komentarz tekstu, usuwając średnik.
macOS
- Pobierz język PHP w wersji 7.1.4.
- Zainstaluj język PHP i zapoznaj się z podręcznikiem języka PHP w celu przeprowadzenia dalszej konfiguracji.
Pobieranie informacji o połączeniu
Uzyskaj parametry połączenia potrzebne do nawiązania połączenia z usługą Azure Database for PostgreSQL. Potrzebna jest w pełni kwalifikowana nazwa serwera i poświadczenia logowania.
- Zaloguj się w witrynie Azure Portal.
- W menu po lewej stronie w witrynie Azure Portal wybierz pozycję Wszystkie zasoby, a następnie wyszukaj utworzony serwer (na przykład mydemoserver).
- Wybierz nazwę serwera.
- Po przejściu do panelu Przegląd serwera zanotuj nazwę serwera i nazwę logowania administratora serwera. Jeśli zapomnisz hasła, możesz również je zresetować z poziomu tego panelu.
Łączenie i tworzenie tabeli
Użyj poniższego kodu, aby nawiązać połączenie i utworzyć tabelę przy użyciu instrukcji CREATE TABLE SQL, a następnie instrukcji INSERT INTO SQL, aby dodać wiersze do tabeli.
Metoda wywołania kodu pg_connect() służy do nawiązywania połączenia z usługą Azure Database for PostgreSQL. Następnie wywołuje metodę — pg_query() — kilka razy, aby uruchomić kilka poleceń, a pg_last_error(), aby sprawdzić szczegóły, czy wystąpił błąd za każdym razem. Następnie wywołuje metodę pg_close(), aby zamknąć połączenie.
Zastąp $host
parametry , , $database
$user
i $password
swoimi wartościami.
<?php
// Initialize connection variables.
$host = "mydemoserver.postgres.database.azure.com";
$database = "mypgsqldb";
$user = "mylogin@mydemoserver";
$password = "<server_admin_password>";
// Initialize connection object.
$connection = pg_connect("host=$host dbname=$database user=$user password=$password")
or die("Failed to create connection to database: ". pg_last_error(). "<br/>");
print "Successfully created a connection to the database.<br/>";
// Drop the previous table of the same name if one exists.
$query = "DROP TABLE IF EXISTS inventory;";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). "<br/>");
print "Finished dropping table (if existed).<br/>";
// Create table.
$query = "CREATE TABLE inventory (id serial PRIMARY KEY, name VARCHAR(50), quantity INTEGER);";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). "<br/>");
print "Finished creating table.<br/>";
// Insert some data into the table.
$name = '\'banana\'';
$quantity = 150;
$query = "INSERT INTO inventory (name, quantity) VALUES ($name, $quantity);";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). "<br/>");
$name = '\'orange\'';
$quantity = 154;
$query = "INSERT INTO inventory (name, quantity) VALUES ($name, $quantity);";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). "<br/>");
$name = '\'apple\'';
$quantity = 100;
$query = "INSERT INTO inventory (name, quantity) VALUES ($name, $quantity);";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error()). "<br/>";
print "Inserted 3 rows of data.<br/>";
// Closing connection
pg_close($connection);
?>
Odczyt danych
Użyj poniższego kodu, aby nawiązać połączenie i odczytać dane za pomocą instrukcji SELECT języka SQL.
Metoda wywołania kodu pg_connect() służy do nawiązywania połączenia z usługą Azure Database for PostgreSQL. Następnie kod wywołuje metodę pg_query() w celu uruchomienia polecenia SELECT, zachowując wyniki w zestawie wyników, i metodę pg_last_error() w celu sprawdzenia błędów, jeśli wystąpił błąd. Aby odczytać zestaw wyników, metoda pg_fetch_row() jest wywoływana w postaci pętli, jeden raz dla każdego wiersza, a dane są pobierane w tablicy $row
, z jedną wartością danych na kolumnę w każdej pozycji tablicy. Aby zwolnić zestaw wyników, należy wywołać metodę pg_free_result(). W kolejnym kroku kod wywołuje metodę pg_close() w celu zamknięcia połączenia.
Zastąp $host
parametry , , $database
$user
i $password
swoimi wartościami.
<?php
// Initialize connection variables.
$host = "mydemoserver.postgres.database.azure.com";
$database = "mypgsqldb";
$user = "mylogin@mydemoserver";
$password = "<server_admin_password>";
// Initialize connection object.
$connection = pg_connect("host=$host dbname=$database user=$user password=$password")
or die("Failed to create connection to database: ". pg_last_error(). "<br/>");
print "Successfully created a connection to the database. <br/>";
// Perform some SQL queries over the connection.
$query = "SELECT * from inventory";
$result_set = pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). "<br/>");
while ($row = pg_fetch_row($result_set))
{
print "Data row = ($row[0], $row[1], $row[2]). <br/>";
}
// Free result_set
pg_free_result($result_set);
// Closing connection
pg_close($connection);
?>
Aktualizowanie danych
Użyj poniższego kodu, aby nawiązać połączenie i zaktualizować dane za pomocą instrukcji UPDATE języka SQL.
Metoda wywołania kodu pg_connect() służy do nawiązywania połączenia z usługą Azure Database for PostgreSQL. Następnie kod wywołuje metodę pg_query() w celu uruchomienia polecenia i metodę pg_last_error() w celu sprawdzenia szczegółów, jeśli wystąpił błąd. W kolejnym kroku kod wywołuje metodę pg_close() w celu zamknięcia połączenia.
Zastąp $host
parametry , , $database
$user
i $password
swoimi wartościami.
<?php
// Initialize connection variables.
$host = "mydemoserver.postgres.database.azure.com";
$database = "mypgsqldb";
$user = "mylogin@mydemoserver";
$password = "<server_admin_password>";
// Initialize connection object.
$connection = pg_connect("host=$host dbname=$database user=$user password=$password")
or die("Failed to create connection to database: ". pg_last_error(). ".<br/>");
Print "Successfully created a connection to the database. <br/>";
// Modify some data in a table.
$new_quantity = 200;
$name = '\'banana\'';
$query = "UPDATE inventory SET quantity = $new_quantity WHERE name = $name;";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). ".<br/>");
print "Updated 1 row of data. </br>";
// Closing connection
pg_close($connection);
?>
Usuwanie danych
Użyj poniższego kodu, aby nawiązać połączenie i odczytać dane za pomocą instrukcji DELETE języka SQL.
Metoda wywołania kodu pg_connect() służy do nawiązywania połączenia z usługą Azure Database for PostgreSQL. Następnie kod wywołuje metodę pg_query() w celu uruchomienia polecenia i metodę pg_last_error() w celu sprawdzenia szczegółów, jeśli wystąpił błąd. W kolejnym kroku kod wywołuje metodę pg_close() w celu zamknięcia połączenia.
Zastąp $host
parametry , , $database
$user
i $password
swoimi wartościami.
<?php
// Initialize connection variables.
$host = "mydemoserver.postgres.database.azure.com";
$database = "mypgsqldb";
$user = "mylogin@mydemoserver";
$password = "<server_admin_password>";
// Initialize connection object.
$connection = pg_connect("host=$host dbname=$database user=$user password=$password")
or die("Failed to create connection to database: ". pg_last_error(). ". </br>");
print "Successfully created a connection to the database. <br/>";
// Delete some data from a table.
$name = '\'orange\'';
$query = "DELETE FROM inventory WHERE name = $name;";
pg_query($connection, $query)
or die("Encountered an error when executing given sql statement: ". pg_last_error(). ". <br/>");
print "Deleted 1 row of data. <br/>";
// Closing connection
pg_close($connection);
?>
Czyszczenie zasobów
Aby wyczyścić wszystkie zasoby używane w tym przewodniku Szybki start, usuń grupę zasobów przy użyciu następującego polecenia:
az group delete \
--name $AZ_RESOURCE_GROUP \
--yes
Powiązana zawartość
- Zarządzanie usługą Azure Database for PostgreSQL — serwer elastyczny.
- Szybki start: nawiązywanie połączeń z danymi i wykonywanie zapytań względem nich z wystąpienia elastycznego serwera usługi Azure Database for PostgreSQL za pomocą języka Python.
- Szybki start: nawiązywanie połączeń i wykonywanie zapytań o dane z wystąpienia elastycznego serwera usługi Azure Database for PostgreSQL za pomocą języka Java.
- Szybki start: używanie platformy .NET (C#) do nawiązywania połączeń i wykonywania zapytań o dane z wystąpienia serwera elastycznego usługi Azure Database for PostgreSQL.
- Szybki start: nawiązywanie połączeń i wykonywanie zapytań o dane z wystąpienia elastycznego serwera usługi Azure Database for PostgreSQL przy użyciu języka Go.
- Szybki start: nawiązywanie połączeń z elastycznym serwerem usługi Azure Database for PostgreSQL i wykonywanie zapytań o dane z wystąpienia serwera elastycznego usługi Azure Database for PostgreSQL.
- Szybki start: importowanie danych z usługi Azure Database for PostgreSQL — serwer elastyczny w usłudze Power BI.