Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Membuat pernyataan kebijakan IAM khusus untuk mengakses data di Amazon Neptunus
Pernyataan kebijakan akses data Neptunus menggunakan tindakan akses data, sumber daya, dan kunci kondisi, yang semuanya didahului oleh awalan. neptune-db:
Topik
Menggunakan tindakan kueri dalam pernyataan kebijakan akses data Neptunus
Ada tiga tindakan kueri Neptunus yang dapat digunakan dalam pernyataan kebijakan akses data, yaitu,, dan. ReadDataViaQuery WriteDataViaQuery DeleteDataViaQuery Kueri tertentu mungkin memerlukan izin untuk melakukan lebih dari satu tindakan ini, dan mungkin tidak selalu jelas kombinasi tindakan apa yang harus diizinkan untuk menjalankan kueri.
Sebelum menjalankan kueri, Neptunus menentukan izin yang diperlukan untuk menjalankan setiap langkah kueri, dan menggabungkannya ke dalam set lengkap izin yang dibutuhkan kueri. Perhatikan bahwa set lengkap izin ini mencakup semua tindakan yang mungkin dilakukan kueri, yang belum tentu merupakan kumpulan tindakan yang sebenarnya akan dilakukan kueri saat dijalankan di atas data Anda.
Ini berarti bahwa untuk mengizinkan kueri tertentu dijalankan, Anda harus memberikan izin untuk setiap tindakan yang mungkin dilakukan kueri, apakah itu benar-benar melakukannya atau tidak.
Berikut adalah beberapa contoh pertanyaan Gremlin di mana ini dijelaskan secara lebih rinci:
-
g.V().count()g.V()dancount()hanya memerlukan akses baca, jadi kueri secara keseluruhan hanya membutuhkanReadDataViaQueryakses. -
g.addV()addV()perlu memeriksa apakah simpul dengan ID yang diberikan ada atau tidak sebelum memasukkan yang baru. Ini berarti membutuhkan keduanyaReadDataViaQuerydanWriteDataViaQueryakses. -
g.V('1').as('a').out('created').addE('createdBy').to('a')g.V('1').as('a')danout('created')hanya memerlukan akses baca, tetapiaddE().from('a')memerlukan akses baca dan tulis karenaaddE()perlu membacafromdantosimpul dan memeriksa apakah tepi dengan ID yang sama sudah ada sebelum menambahkan yang baru. Oleh karena itu, kueri secara keseluruhan membutuhkan keduanyaReadDataViaQuerydanWriteDataViaQueryakses. -
g.V().drop()g.V()hanya membutuhkan akses baca.drop()membutuhkan akses baca dan hapus karena perlu membaca simpul atau tepi sebelum menghapusnya, sehingga kueri secara keseluruhan membutuhkan keduanyaReadDataViaQuerydanDeleteDataViaQueryakses. -
g.V('1').property(single, 'key1', 'value1')g.V('1')hanya membutuhkan akses baca, tetapiproperty(single, 'key1', 'value1')membutuhkan akses baca, tulis, dan hapus. Di sini,property()langkah menyisipkan kunci dan nilai jika mereka belum ada di simpul, tetapi jika mereka sudah ada, itu menghapus nilai properti yang ada dan menyisipkan nilai baru di tempatnya. Oleh karena itu, query secara keseluruhan membutuhkanReadDataViaQuery,WriteDataViaQuery, danDeleteDataViaQueryakses.Setiap kueri yang berisi
property()langkah akan membutuhkanReadDataViaQuery,WriteDataViaQuery, danDeleteDataViaQueryizin.
Berikut adalah beberapa contoh OpenCypher:
-
MATCH (n) RETURN nKueri ini membaca semua node dalam database dan mengembalikannya, yang hanya membutuhkan
ReadDataViaQueryakses. -
MATCH (n:Person) SET n.dept = 'AWS'Kueri ini membutuhkan
ReadDataViaQuery,WriteDataViaQuery, danDeleteDataViaQueryakses. Ia membaca semua node dengan label 'Orang' dan menambahkan properti baru dengan kuncideptdan nilaiAWSuntuk mereka, atau jikadeptproperti sudah ada, itu menghapus nilai lama dan menyisipkanAWSsebagai gantinya. Juga, jika nilai yang akan ditetapkan adalahnull,SETmenghapus properti sama sekali.Karena
SETklausa mungkin dalam beberapa kasus perlu menghapus nilai yang ada, klausa selalu membutuhkanDeleteDataViaQueryizin sertaReadDataViaQuerydanWriteDataViaQueryizin. -
MATCH (n:Person) DETACH DELETE nKebutuhan
ReadDataViaQuerydanDeleteDataViaQueryizin kueri ini. Ia menemukan semua node dengan labelPersondan menghapusnya bersama dengan tepi yang terhubung ke node tersebut dan label dan properti terkait. -
MERGE (n:Person {name: 'John'})-[:knows]->(:Person {name: 'Peter'}) RETURN nKebutuhan
ReadDataViaQuerydanWriteDataViaQueryizin kueri ini.MERGEKlausa cocok dengan pola tertentu atau membuatnya. Karena, penulisan dapat terjadi jika pola tidak cocok, izin menulis diperlukan serta izin baca.