Abstrak
Artikel ini mengambil database Oracle sebagai contoh untuk memperkenalkan metode penyimpanan dan pemrosesan data berbentuk sederhana dan universal ketika mengembangkan aplikasi WEB menggunakan teknologi JSP untuk mengurangi beban kerja pengembangan dan menyediakan kode program utama.
Pendahuluan
Teknologi J2EE (Java 2 Enterprise Edition) telah banyak digunakan dalam pengembangan aplikasi Web. Teknologi JavaBean dan Servlet memberi pengembang lingkungan pengembangan yang lebih jelas. Teknologi JSP digunakan untuk menampilkan halaman, dan teknologi Servlet digunakan untuk menyelesaikan sejumlah besar proses bisnis. , menggunakan Beans untuk menyimpan data dan beberapa pemrosesan bisnis. Dalam aplikasi WEB, pekerjaan pemrosesan penyimpanan data bisnis dalam database seringkali sangat sulit. Salah satu bentuk utama adalah menyimpan data formulir dalam database. Seluruh proses pemrosesan aplikasi melibatkan sejumlah besar operasi penyimpanan data, dan masing-masing formulir perlu diproses. Pengembang membutuhkan banyak waktu dan energi untuk menulis program penyimpanan data yang sesuai secara terpisah. Metode apa yang digunakan untuk mengurangi beban kerja pengembangan penyimpanan data formulir adalah pertanyaan yang patut dipelajari.
Dua metode penyimpanan dan pemrosesan data formulir yang umum:
1. Tulis kode program yang sesuai untuk setiap formulir
di halaman JSP atau JavaBean atau Servlet. Gunakan fungsi request.getparameter() untuk mengekstrak data yang dikirimkan oleh formulir satu per satu, atau tulis JavaBean yang sesuai. Gunakan metode setProperty untuk mengambil data secara otomatis ke dalam JavaBean, lalu buat pernyataan SQL (sisipkan, perbarui, hapus), dan terakhir jalankan fungsi eksekusiupdate() untuk menyelesaikan penyimpanan tabel data.
2. Secara otomatis menghasilkan kode program JavaBean untuk setiap tabel data.
Sistem database harus mendukung pengguna untuk membaca struktur tabel dan mengidentifikasi bidang kunci. Gunakan alat pengembangan cepat berorientasi objek, seperti PowerBuilder, Delphi, dll., untuk mengembangkan program pembuatan kode Java secara otomatis. Dalam program ini, struktur tabel database dibaca: nama field, tipe data, panjang data, dan kode JavaBean dibuat secara otomatis. Dalam kode ini, tentukan variabel dengan nama yang sama sesuai dengan bidang dalam tabel, buat metode setValue dan getValue untuk semua variabel, dan buat fungsi penyisipan, perbarui, dan hapus untuk menangani pembuatan dan eksekusi pernyataan SQL untuk penyisipan, pembaruan, dan hapus masing-masing.
Pada halaman pengolahan data yang dikirimkan oleh form, tulis kode berikut untuk menyimpan data form di JavaBean:
<jsp: useBean id="table" class="table1_bean" />
<jsp:setProperty name="table" property="*" />
(Catatan: table1_bean adalah JavaBean yang dihasilkan secara otomatis sesuai dengan tabel tertentu yang disebutkan di atas)
Kemudian panggil fungsi insert, update, dan delete di table1_bean untuk menyelesaikan penyimpanan tabel data dan mengembalikan hasil eksekusi. menyukai:
<%boolean sukses =table.insert();
Metode pertama sederhana dan intuitif, tetapi Anda perlu menulis program pemrosesan data yang sesuai untuk setiap formulir. Untuk aplikasi yang sedikit lebih besar, jumlah formulir mungkin banyak, sehingga mengakibatkan beban kerja pengembangan yang berat dan efisiensi pengembangan yang rendah. Ketika struktur tabel berubah, seperti menambah atau mengurangi bidang, program pemrosesan data terkait perlu dimodifikasi.
Metode kedua jauh lebih sederhana daripada yang pertama. Pemrosesan data setiap tabel data diimplementasikan oleh JavaBean yang sesuai. JavaBean dibuat secara otomatis dan tidak perlu ditulis ketika struktur tabel berubah, Anda hanya perlu membuat ulang yang baru JavaBean dan timpa setelah dikompilasi dengan Java. Kelas java asli dapat digunakan. Namun, metode ini memerlukan pengembangan program pembuatan otomatis JavaBean, dan JavaBeans perlu dibuat ulang dan dikompilasi ketika struktur tabel berubah.
Memperkenalkan metode sederhana dan universal untuk menyimpan data formulir
dalam pengembangan aplikasi WEB. Banyak formulir dikirimkan ke server backend setelah verifikasi data sederhana di browser front-end sebuah tabel data. Dalam hal ini, kita cukup menulis sebuah program untuk memproses formulir-formulir ini secara seragam dan menyimpan data dalam tabel data yang sesuai. Metode ini juga memerlukan sistem database untuk mendukung pembacaan struktur tabel dan identifikasi field kunci. Kami menggunakan teknologi JSP untuk menulis program ini, dan file program diberi nama DbdataStore.jsp.
1. Format pemanggilan
Metode pemanggilan Action form pada halaman web adalah sebagai berikut:
<Form Name=Frm1 Method=Post Action="DBdataStore.jsp? tablename=table1&OperType=...">
table1 adalah nama tabel dari tabel database dimana data akan disimpan, dan operasi OperType Ada tiga jenis: menyisipkan, memperbarui, dan menghapus.
Nilai nama di <input type=text name=…>, <textarea name=…><select name=…> di formulir harus sama dengan nama field pada tabel data formulir diekstraksi satu per satu di DBdataStore.jsp Jika tidak ada input yang ditentukan dalam formulir dan nilai yang dihasilkan adalah nilai nol, bidang tersebut tidak akan diproses.
2. Lihat definisi dengan mengambil Oracle sebagai contoh
1) Buat tampilan tipe data untuk setiap kolom tabel
BUAT ATAU GANTI LIHAT v_dbstru AS SELECT nama_tabel, nama_kolom, tipe_data, panjang_data, presisi_data, skala_data, id_kolom
FROM all_tab_columns WHERE owner='user1'; //pengguna1 adalah pemilik tabel data.
2) Buat tampilan kolom kunci dari tabel
CREATE OR REPLACE VIEW v_pkey_column AS
PILIH b.nama_tabel, b.nama_kolom, b.posisi
DARI all_constraints a, all_cons_columns b
WHERE a.owner=b.owner AND a.constraint_name=b.constraint_name AND a.owner='user1' AND a.constraint_type='P';
3. Kode program utama
1) Inisialisasi program
String tablename=request.getParameter(" tablename"); //Ekstrak nama tabel
String OperType=request.getParameter("OperType"); //Ekstrak tipe operasi
String sFieldValue="";//Menyimpan nilai data bidang yang dikirimkan oleh formulir
String fieldname="", Datatype="" //Nama field penyimpanan, tipe data field
int iFieldvalue=0;
String updateSql="", dimanaSql=" di mana ", insSql1="", insSql2="", opSql="", strSql="";
HasilSet rs1=null, rs2=null;
insSql1="masukkan ke dalam "+namatabel+" (";
insSql2="values(";
2) Hasilkan bagian bidang kunci dari pernyataan sql
dan hasilkan bagian bidang kuncidari
pernyataan penyisipan, seperti: masukkan ke dalam tabel1(id dan nilai(100));
menghasilkan pernyataan pembaruan dan penghapusan di mana bagian, seperti: di mana id=100;
ketika jenis operasi diperbarui, data bidang kunci tidak akan diubah dalam formulir web.
rs1=Stmt.executeQuery("PILIH nama_kolom FROM v_pkey_column WHERE table_name='"+tablename+"'"); //Dapatkan nama field kunci
while(rs1.berikutnya()){
namabidang=rs1.getString("nama_kolom");
rs2=Stmt.executeQuery("SELECT data_type FROM v_dbstru WHERE table_name='"+tablename+"' AND Column_name='"+fieldname+"'"); //Dapatkan tipe data kolom kunci if(rs2.next()){
Tipe Data=rs2.getString("tipe_data");
sFieldValue=permintaan.getParameter(namabidang.toLowerCase());
//Buat bagian bidang kunci dari pernyataan penyisipan if(OperType.equals("insert")){
insSql1+=nama bidang+"";
jika((sFieldValue==null) ){
//Bila nilai data field kunci tidak dikirimkan dalam formulir, artikel ini hanya akan memprosesnya sebagai tipe numerik, dan nilai data akan dihitung sesuai dengan nomor seri.
rs2= Stmt.executeQuery("PILIH maks("+namabidang+")+1 DARI "+namatabel.toString(iFieldvalue)+"," ; }else if(Tipe data.sama dengan("TANGGAL")){
insSql2+= "Sampai_Tanggal('" + sFieldValue + "','YYYY-MM-DD'),";
}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){
insSql2+="'" + sFieldValue+"',";}
lain /*NUMBER, FLOAT */ insSql2+=sFieldValue+","}
//Buat pembaruan dan hapus pernyataan di mana bagian: di mana nama bidang=... DAN
if(OperType.equals("update") || OperType.equals("hapus")){
if(Tipe data.sama dengan("TANGGAL")){
di manaSql+=namabidang+"=Tanggal_Sampai('" + sFieldValue + "','YYYY-MM-DD') DAN ";
}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){
di manaSql+=namabidang+"='" + sFieldValue+"' DAN ";}
else /*NUMBER, FLOAT */ WhereSql+=fieldname+"="+ sFieldValue+" AND ";}
}
}
WhereSql=whereSql.substring(0, WhereSql.length()-4);
3) Pernyataan sql dari bagian bidang non-kunci menghasilkan
pernyataan pembaruan, seperti: perbarui tabel1 set kolom1=nilai1,... di mana id= 100
pernyataan penyisipan, seperti: masukkan ke dalam tabel1(id, kolom1,…)nilai(100, nilai1,…)
updateSql="update "+namatabel+" set ";
struktur )";
rs1=Stmt.executeQuery(strSql); //Dapatkan nama field dan tipe data dari field bukan kunci
while(rs1.berikutnya()){
fieldname=rs1.getString("column_name"); Datatype=rs1.getString("data_type"); sFieldValue=request.getParameter(fieldname.toLowerCase()); //Jika formulir tidak mengirimkan nilai kolom, abaikan bidang Memproses if((sFieldValue!=null)){
//Buat pernyataan penyisipan =insSql1+insSql2, yaitu, masukkan ke nama tabel(… dan nilai(…)
if(OperType.equals("insert")){ insSql1+=fieldname+"";
if(Tipe data.sama dengan("TANGGAL")){
insSql2+= "Sampai_Tanggal('" + sFieldValue + "','YYYY-MM-DD'),";
} else if(Tipe Data.sama dengan("VARCHAR2") || Tipe Data.sama dengan("CHAR")){
insSql2+="'" + sFieldValue+"',";}else /*NUMBER,FLOAT*/ insSql2+= sFieldValue+",";}
//Buat pernyataan pembaruan=updateSql+whereSql, yaitu, perbarui kumpulan nama tabel... di mana nama bidang=... if(OperType.equals("update")){
if(Tipe data.sama dengan("TANGGAL")){
updateSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD'),";
}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){
updateSql+=fieldname+"='" + sFieldValue,1}+"',";}else /*NUMBER,FLOAT*/ updateSql+=fieldname+"="+sFieldValue+",";}))
rs1.close();
4) Buat pernyataan sql lengkap dan jalankan
if(OperType.equals("insert"))
opSql=insSql1.substring(0, insSql1.length()-1)+")"+insSql2.substring(0, insSql2.length()-1)+")";
if(OperType.equals("perbarui"))
opSql=updateSql.substring(0, updateSql.length()-1)+" "+whereSql; if(OperType.equals("hapus"))
opSql="hapus DARI "+namatabel+" "+whereSql;
//Pernyataan sql lengkap opSql telah dibuat
coba{sqlnrows=Stmt.executeUpdate(opSql);}
catch(SQLException e){out.println("SQLException:"+opSql);}
4. Fitur
Metode ini menggunakan program ini secara seragam untuk semua formulir yang disimpan secara langsung. Ini bersifat universal dan tidak perlu digunakan untuk setiap formulir atau setiap formulir. Program terkait dikembangkan secara independen untuk tabel data. Beban kerja pengembangan sangat kecil dan panggilannya sangat sederhana. Pada saat yang sama, ketika struktur tabel berubah, program DBdataStore.jsp tidak perlu diubah. Program ini juga dapat ditulis ulang sebagai Servelet, dan format pemanggilannya adalah <Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=...">.
Kesimpulan
Dalam aplikasi web, jika data formulir memerlukan verifikasi atau pemrosesan data lebih lanjut di latar belakang server setelah penyerahan, maka metode kedua perlu digunakan. Namun dalam banyak kasus, pengguna memasukkan atau mengubah data dalam formulir, menggunakan JavaScript untuk sekadar memverifikasi atau memproses data di browser front-end, lalu mengirimkannya. Tidak ada pemrosesan yang dilakukan di server back-end, dan data dikirimkan oleh formulir langsung disimpan dalam database dalam sebuah tabel. Saat ini, menggunakan metode ketiga sangatlah sederhana dan dapat sangat mengurangi beban kerja pengembang.