Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Membuat pernyataan IAM kebijakan 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 membutuhkanReadDataViaQuery
akses. -
g.addV()
addV()
perlu memeriksa apakah simpul dengan ID yang diberikan ada atau tidak sebelum memasukkan yang baru. Ini berarti membutuhkan keduanyaReadDataViaQuery
danWriteDataViaQuery
akses. -
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 membacafrom
danto
simpul dan memeriksa apakah tepi dengan ID yang sama sudah ada sebelum menambahkan yang baru. Oleh karena itu, kueri secara keseluruhan membutuhkan keduanyaReadDataViaQuery
danWriteDataViaQuery
akses. -
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 keduanyaReadDataViaQuery
danDeleteDataViaQuery
akses. -
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
, danDeleteDataViaQuery
akses.Setiap kueri yang berisi
property()
langkah akan membutuhkanReadDataViaQuery
,WriteDataViaQuery
, danDeleteDataViaQuery
izin.
Berikut adalah beberapa openCypher contoh:
-
MATCH (n) RETURN n
Kueri ini membaca semua node dalam database dan mengembalikannya, yang hanya membutuhkan
ReadDataViaQuery
akses. -
MATCH (n:Person) SET n.dept = 'AWS'
Kueri ini membutuhkan
ReadDataViaQuery
,WriteDataViaQuery
, danDeleteDataViaQuery
akses. Ia membaca semua node dengan label 'Orang' dan menambahkan properti baru dengan kuncidept
dan nilaiAWS
untuk mereka, atau jikadept
properti sudah ada, itu menghapus nilai lama dan menyisipkanAWS
sebagai gantinya. Juga, jika nilai yang akan ditetapkan adalahnull
,SET
menghapus properti sama sekali.Karena
SET
klausa mungkin dalam beberapa kasus perlu menghapus nilai yang ada, klausa selalu membutuhkanDeleteDataViaQuery
izin sertaReadDataViaQuery
danWriteDataViaQuery
izin. -
MATCH (n:Person) DETACH DELETE n
Kebutuhan
ReadDataViaQuery
danDeleteDataViaQuery
izin kueri ini. Ia menemukan semua node dengan labelPerson
dan menghapusnya bersama dengan tepi yang terhubung ke node tersebut dan label dan properti terkait. -
MERGE (n:Person {name: 'John'})-[:knows]->(:Person {name: 'Peter'}) RETURN n
Kebutuhan
ReadDataViaQuery
danWriteDataViaQuery
izin kueri ini.MERGE
Klausa cocok dengan pola tertentu atau membuatnya. Karena, penulisan dapat terjadi jika pola tidak cocok, izin menulis diperlukan serta izin baca.