SQLAlchemy ORM - Memperbarui Objek
Pada bab ini, kita akan melihat bagaimana mengubah atau memperbarui tabel dengan nilai yang diinginkan.
Untuk mengubah data atribut tertentu dari objek apa pun, kita harus memberikan nilai baru padanya dan melakukan perubahan untuk membuat perubahan tetap ada.
Mari kita ambil objek dari tabel yang pengenal kunci utamanya, di tabel Pelanggan dengan ID = 2. Kita bisa menggunakan metode get () sesi sebagai berikut -
x = session.query(Customers).get(2)
Kami dapat menampilkan konten dari objek yang dipilih dengan kode yang diberikan di bawah ini -
print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)
Dari tabel pelanggan kami, output berikut harus ditampilkan -
Name: Komal Pande Address: Koti, Hyderabad Email: [email protected]
Sekarang kita perlu memperbarui bidang Alamat dengan memberikan nilai baru seperti yang diberikan di bawah ini -
x.address = 'Banjara Hills Secunderabad'
session.commit()
Perubahan tersebut akan terus ditampilkan dalam database. Sekarang kita mengambil objek yang sesuai dengan baris pertama dalam tabel dengan menggunakanfirst() method sebagai berikut -
x = session.query(Customers).first()
Ini akan mengeksekusi ekspresi SQL berikut -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
LIMIT ? OFFSET ?
Parameter yang terikat adalah LIMIT = 1 dan OFFSET = 0 masing-masing yang berarti baris pertama akan dipilih.
print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)
Sekarang, output untuk kode di atas yang menampilkan baris pertama adalah sebagai berikut -
Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
Sekarang ubah atribut nama dan tampilkan isinya menggunakan kode di bawah ini -
x.name = 'Ravi Shrivastava'
print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)
Output dari kode diatas adalah -
Name: Ravi Shrivastava Address: Station Road Nanded Email: [email protected]
Meskipun perubahan ditampilkan, itu tidak dilakukan. Anda dapat mempertahankan posisi persisten sebelumnya dengan menggunakanrollback() method dengan kode di bawah ini.
session.rollback()
print ("Name: ", x.name, "Address:", x.address, "Email:", x.email)
Isi asli dari rekaman pertama akan ditampilkan.
Untuk pembaruan massal, kami akan menggunakan metode update () dari objek Query. Mari kita coba dan beri awalan, 'Mr.' untuk memberi nama di setiap baris (kecuali ID = 2). Pernyataan update () yang sesuai adalah sebagai berikut -
session.query(Customers).filter(Customers.id! = 2).
update({Customers.name:"Mr."+Customers.name}, synchronize_session = False)
The update() method requires two parameters as follows −
Kamus nilai kunci dengan kunci menjadi atribut yang akan diperbarui, dan nilai adalah konten baru dari atribut.
sync_session atribut yang menyebutkan strategi untuk memperbarui atribut dalam sesi. Nilai yang valid adalah salah: untuk tidak menyinkronkan sesi, fetch: melakukan kueri pemilihan sebelum pembaruan untuk menemukan objek yang cocok dengan kueri pembaruan; dan evaluasi: evaluasi kriteria pada objek dalam sesi.
Tiga dari 4 baris pada tabel akan memiliki nama yang diawali dengan 'Mr.' Namun, perubahan tidak dilakukan dan karenanya tidak akan tercermin dalam tampilan tabel SQLiteStudio. Ini akan disegarkan hanya ketika kita menjalankan sesi.