cari
Rumahpangkalan datatutorial mysqlApakah perbezaan sintaks antara pangkalan data oracle dan mysql

Perbezaan: 1. MySQL tidak mempunyai jenis Nombor, tetapi Oracle mempunyai 2. Jenis Tarikh dalam MySQL hanya mewakili tarikh, dan jenis Tarikh dalam Oracle mewakili tarikh dan masa; daripada rentetan, Oracle menggunakan length(), MySQL menggunakan char_length() dan sebagainya.

Apakah perbezaan sintaks antara pangkalan data oracle dan mysql

Persekitaran pengendalian tutorial ini: sistem windows7, versi mysql8, komputer Dell G3.

Baru-baru ini, saya perlu memindahkan projek dan menukar pangkalan data daripada Oracle kepada MySQL. Oleh kerana sintaks antara kedua-duanya adalah sebahagiannya berbeza, adalah perlu untuk menukar fungsi/jenis yang boleh digunakan dalam Oracle tetapi tidak dalam MySQL kepada yang boleh digunakan dalam MySQL Berikut ialah ringkasan beberapa perbezaan sintaks:

1 Jenis data

1 Jenis nombor

Tiada jenis Nombor dalam MySQL, tetapi terdapat jenis int/ Decimal, Number(5,1) dalam Oracle sepadan dengan perpuluhan(5,1) dalam MySQL, dan Number(5) sepadan dengan int(5).

Terdapat banyak jenis angka dalam MySQL, dan ia dibahagikan kepada kategori yang lebih terperinci, termasuk jenis tinyint, smallint, mediumint, bigint dan jenis lain

2

Jenis alternatif yang sepadan dengan jenis Oracle Varchar2(n) dalam MySQL ialah jenis varchar(n).

3. Jenis Tarikh

Jenis tarikh dan masa dalam MySQL termasuk Date, Time, Datetime dan jenis lain The Date type dalam MySQL hanya mewakili tarikh (tahun-. month-day ), jenis Masa hanya mewakili masa (hour:minute:second), manakala jenis Datetime mewakili tarikh dan masa (year-month-day hour:minute:second) Jenis Tarikh dalam Oracle adalah konsisten dengan Datetime taip MySQL.

2. Fungsi

1. panjang(str) fungsi

panjang dalam Oracle ( str) ialah fungsi untuk mendapatkan panjang rentetan Fungsi yang sepadan dalam MySQL ialah char_length(str).

2. Fungsi sys_guid()

Oracle boleh menggunakan fungsi sys_guid() untuk menjana jujukan rawak, dan MySQL boleh menjana jujukan rawak melalui UUID().

3. Fungsi pemformatan masa

Tukar masa kepada masa rentetan MySQL date_format(NOW(),'%Y-%m-%d') Sepadan dengan to_char( sysdate, 'YYYY-MM-DD') dalam Oracle's Oracle;

Tukar rentetan masa ke masa taip MySQL str_to_date('2019-01-01','%Y-% m-%d') sepadan dengan to_date('2019-01-01', 'YYYY-MM-DD');

dalam Oracle termasuk penukaran fungsi jam, minit dan saat: DATE_FORMAT(NOW(),'% Y-%m- %d %H:%i:%s'), str_to_date('2019-01-01','%Y-%m-%d %H:%i:%s').

4. Fungsi bersyarat (nvl(), nvl2(), nyahkod())

nvl(tab.columnName, 0): Jika nilai tab. columnName ialah Jika ia kosong, nilai pulangan akan menjadi 0, jika tidak ia akan menjadi tab.columnName fungsi MySQL yang sepadan ialah: ifnull(tab.columnName, 0).

nvl2(expr1,expr2,expr3): Jika expr1 bukan null, kembalikan expr2, sebaliknya kembalikan expr3; fungsi MySQL yang sepadan ialah: if(expr1,expr2,expr3).

DEKODE(nilai, val1, val2, val3): Jika nilai sama dengan val1, kembalikan val2, jika tidak, kembalikan val3 MySQL boleh diwakili oleh fungsi IF: if (value=val1, val2, val3) ;

DEKODE(nilai, if1, val1, if2,val2,...,ifn, valn, val): Jika nilai sama dengan if1, kembalikan val1, jika nilai sama dengan if2, kembalikan nilai2. ..Jika nilai adalah sama dengan ifn , maka kembalikan valn, jika tidak, kembalikan val MySQL boleh menilai penghakiman jenis ini melalui kes apabila kemudian tamat;l, iaitu: kes apabila nilai=jika1 maka val1 apabila nilai=jika2 maka val2; ,,apabila value=ifn maka valn else val end;

5 fungsi trunc()

TRUNC(12.123): Mengembalikan integer (12); function: truncate(12.123, 0) ;

TRUNC(12.123, 2): Nilai pulangan mengekalkan 2 sebagai perpuluhan (12.12); MySQL fungsi yang sepadan:

TRUNC(SYSDATE): Nilai pulangan ialah (2019-07-26 00:00:00 MySQL sepadan dengan cast(now() sebagai datetime): nilai pulangan ialah (2019-07-26 14:11:38); );

MySQL Sintaks fungsi cast ialah: CAST (jenis xxx AS) (Jenis yang tersedia ialah: binari, dengan kesan awalan binari: BINARI; jenis aksara, dengan parameter: CHAR(); tarikh: TARIKH; masa: MASA; tarikh dan jenis masa: DATETIME; nombor titik terapung: integer tidak bertanda: UNTANDA)

6 to_char()

to_char(123): Tukar nombor Tukar 123 kepada rentetan 123; fungsi yang sepadan dalam MySQL ialah CAST(123 AS CHAR(3)); 123 kepada jenis angka; fungsi yang sepadan dalam MySQL adalah cast('123' sebagai DITANDATANGANI);

7 sysdate masa semasa

sysdate: Mengembalikan tarikh dan masa semasa; fungsi yang sepadan untuk MySQL ialah sekarang( );

2. Penggabungan rentetan ||. ||' untuk menyambung rentetan Fungsi concat() menggabungkan rentetan. a.studentname Oracle||'['||a.studentno||']' adalah bersamaan dengan concat(a.studentname MySQL, '[', a.studentno, ']')

3. ROWNUM

Oracle boleh mendapatkan n rekod pertama melalui rownum, dan MySQL boleh mendapatkan n rekod pertama melalui had, tetapi kaedah penulisan kedua-duanya sedikit berbeza. Dalam Oracle Rownum digunakan sebagai sebahagian daripada keadaan where, manakala had dalam MySQL bukan sebahagian daripada keadaan where.

4 Isihan data nol (null first and null last)

5.

Oracle left join dan right join boleh dilaksanakan menggunakan ( ).

-- rownum语法如下:
SELECT * FROM XJ_STUDENT WHERE ROWNUM = 1; -- 查询第一条数据
SELECT * FROM XJ_STUDENT WHERE ROWNUM <= 10; -- 获取前10条数据
-- 但rownum不支持查询后几条或第n(n>1)条数据,例如以下sql是不支持的
SELECT * FROM XJ_STUDENT WHERE ROWNUM > 2;
SELECT * FROM XJ_STUDENT WHERE ROWNUM = 3;

-- limit 语法如下:
SELECT * from fw_department limit 3; -- 查询前3条数据
SELECT * from fw_department limit 2, 4; -- 从第2(序号从0开始)条开始,查4条记录
6. Padamkan sintaks

Sintaks pemadaman MySQL tidak rawak seperti Oracle sebagai contoh, sql berikut boleh dilaksanakan dalam Oracle, tetapi tidak dalam MySQL Boleh.

-- null值排在最前
SELECT * FROM FW_DEPARTMENT A ORDER BY A.REMARK DESC NULLS FIRST
-- null值排在最后
SELECT * FROM FW_DEPARTMENT A ORDER BY A.REMARK DESC NULLS LAST
 
-- MySQL 可通过IF和ISNULL函数达到相同的效果
-- null值排在最后
select * from FW_DEPARTMENT A order by IF(ISNULL(A.REMARK),1,0),A.REMARK desc
-- null值排在最前
select * from FW_DEPARTMENT A order by IF(ISNULL(A.REMARK),0,1),A.REMARK desc

7 Pertanyaan rekursif (mulakan dengan sambung dengan sebelumnya)

MySQL tidak menyokong pertanyaan rekursif ini (bermula dengan sambung dengan sebelumnya), tetapi ia boleh. Dicapai melalui fungsi tersuai.

-- Oracle 左关联
select * from taba, tabb where taba.id = tabb.id(+);
-- Oracle 右关联
select * from taba, tabb where taba.id(+) = tabb.id;
-- MySQL 左关联
select * from taba left join tabb on taba.id=tabb.id;
-- MySQL 右关联
select * from taba right join tabb on taba.id=tabb.id;

8 bergabung ke dalam

MySQL tidak menyokong (bercantum ke dalam), tetapi menyediakan ganti ke dalam dan pada kemas kini kunci pendua untuk mencapai fungsi yang serupa.

-- Oracle 可执行,但MySQL中不能执行
DELETE FROM FW_DEPARTMENT A WHERE A.DEPID = '111';
DELETE FW_DEPARTMENT WHERE DEPID = '111';
-- MySQL中删除语句格式如下:
DELETE FROM FW_DEPARTMENT WHERE DEPID = '111';

9 dengan

With boleh digunakan dalam Oracle untuk membina jadual sementara, tetapi MySQL tidak menyokong untuk sementara jadual, MySQL boleh lulus kurungan, tetapi nama jadual sementara mesti ditetapkan kepada nama jadual sementara.

-- Oracle 递归查询 查询部门ID为‘1111’的所有子部门(包含自身)
SELECT *
FROM FW_DEPARTMENT
START WITH DEPID=&#39;1111&#39;
CONNECT BY PRIOR DEPID = PARENTDEPID;
-- Oracle 递归查询 查询部门ID为‘1111’的所有父部门(包含自身)
SELECT *
FROM FW_DEPARTMENT
START WITH DEPID=&#39;1111&#39;
CONNECT BY PRIOR PARENTDEPID = DEPID;

-- MySQL 先创建fun_getDepIDList函数,用于查询部门ID字符串
CREATE FUNCTION fun_getDepIDList(rootId VARCHAR(32))
RETURNS VARCHAR(6000)
BEGIN 
	DECLARE pTemp VARCHAR(6000);
	DECLARE cTemp VARCHAR(6000);
	SET pTemp=&#39;$&#39;;
	SET cTemp=rootId;
	WHILE cTemp is not null DO
		set pTemp=CONCAT(pTemp,&#39;,&#39;,cTemp);
		SELECT GROUP_CONCAT(depid) INTO cTemp from fw_department
		WHERE FIND_IN_SET(PARENTDEPID,cTemp)>0;
	END WHILE;
	RETURN pTemp;
END;

-- 查询部门ID为‘1111’的所有子部门(包含自己)
select * from fw_department
where FIND_IN_SET(DEPID, fun_getDepIDList(&#39;1111&#39;));

-- 查询部门ID为‘1111’的所有父部门(包含自己)
select * from fw_department
where FIND_IN_SET(&#39;1111&#39;, fun_getDepIDList(DEPID));

[Cadangan berkaitan: tutorial video mysql]

Atas ialah kandungan terperinci Apakah perbezaan sintaks antara pangkalan data oracle dan mysql. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
MySQL: Pengenalan kepada pangkalan data paling popular di duniaMySQL: Pengenalan kepada pangkalan data paling popular di duniaApr 12, 2025 am 12:18 AM

MySQL adalah sistem pengurusan pangkalan data relasi sumber terbuka, terutamanya digunakan untuk menyimpan dan mengambil data dengan cepat dan boleh dipercayai. Prinsip kerjanya termasuk permintaan pelanggan, resolusi pertanyaan, pelaksanaan pertanyaan dan hasil pulangan. Contoh penggunaan termasuk membuat jadual, memasukkan dan menanyakan data, dan ciri -ciri canggih seperti Operasi Join. Kesalahan umum melibatkan sintaks SQL, jenis data, dan keizinan, dan cadangan pengoptimuman termasuk penggunaan indeks, pertanyaan yang dioptimumkan, dan pembahagian jadual.

Kepentingan MySQL: Penyimpanan Data dan PengurusanKepentingan MySQL: Penyimpanan Data dan PengurusanApr 12, 2025 am 12:18 AM

MySQL adalah sistem pengurusan pangkalan data sumber terbuka yang sesuai untuk penyimpanan data, pengurusan, pertanyaan dan keselamatan. 1. Ia menyokong pelbagai sistem operasi dan digunakan secara meluas dalam aplikasi web dan bidang lain. 2. Melalui seni bina pelanggan-pelayan dan enjin penyimpanan yang berbeza, MySQL memproses data dengan cekap. 3. Penggunaan asas termasuk membuat pangkalan data dan jadual, memasukkan, menanyakan dan mengemas kini data. 4. Penggunaan lanjutan melibatkan pertanyaan kompleks dan prosedur yang disimpan. 5. Kesilapan umum boleh disahpepijat melalui pernyataan yang dijelaskan. 6. Pengoptimuman Prestasi termasuk penggunaan indeks rasional dan pernyataan pertanyaan yang dioptimumkan.

Mengapa menggunakan mysql? Faedah dan kelebihanMengapa menggunakan mysql? Faedah dan kelebihanApr 12, 2025 am 12:17 AM

MySQL dipilih untuk prestasi, kebolehpercayaan, kemudahan penggunaan, dan sokongan komuniti. 1.MYSQL Menyediakan fungsi penyimpanan dan pengambilan data yang cekap, menyokong pelbagai jenis data dan operasi pertanyaan lanjutan. 2. Mengamalkan seni bina pelanggan-pelayan dan enjin penyimpanan berganda untuk menyokong urus niaga dan pengoptimuman pertanyaan. 3. Mudah digunakan, menyokong pelbagai sistem operasi dan bahasa pengaturcaraan. 4. Mempunyai sokongan komuniti yang kuat dan menyediakan sumber dan penyelesaian yang kaya.

Huraikan mekanisme penguncian InnoDB (kunci yang dikongsi, kunci eksklusif, kunci niat, kunci rekod, kunci jurang, kunci seterusnya).Huraikan mekanisme penguncian InnoDB (kunci yang dikongsi, kunci eksklusif, kunci niat, kunci rekod, kunci jurang, kunci seterusnya).Apr 12, 2025 am 12:16 AM

Mekanisme kunci InnoDB termasuk kunci bersama, kunci eksklusif, kunci niat, kunci rekod, kunci jurang dan kunci utama seterusnya. 1. Kunci dikongsi membolehkan urus niaga membaca data tanpa menghalang urus niaga lain dari membaca. 2. Kunci eksklusif menghalang urus niaga lain daripada membaca dan mengubah suai data. 3. Niat Kunci mengoptimumkan kecekapan kunci. 4. Rekod Rekod Kunci Kunci Rekod. 5. Gap Lock Locks Index Rakaman Gap. 6. Kunci kunci seterusnya adalah gabungan kunci rekod dan kunci jurang untuk memastikan konsistensi data.

Apakah sebab -sebab biasa prestasi pertanyaan MySQL yang lemah?Apakah sebab -sebab biasa prestasi pertanyaan MySQL yang lemah?Apr 12, 2025 am 12:11 AM

Sebab -sebab utama prestasi pertanyaan MySQL yang lemah termasuk tidak menggunakan indeks, pemilihan pelan pelaksanaan yang salah oleh pengoptimasi pertanyaan, reka bentuk jadual yang tidak munasabah, jumlah data yang berlebihan dan persaingan kunci. 1. Tiada indeks menyebabkan pertanyaan perlahan, dan menambah indeks dapat meningkatkan prestasi dengan ketara. 2. Gunakan perintah Jelaskan untuk menganalisis pelan pertanyaan dan cari ralat pengoptimuman. 3. Membina semula struktur meja dan mengoptimumkan keadaan gabungan dapat meningkatkan masalah reka bentuk jadual. 4. Apabila jumlah data adalah besar, pembahagian dan strategi bahagian meja diterima pakai. 5. Dalam persekitaran konkurensi yang tinggi, mengoptimumkan urus niaga dan strategi mengunci dapat mengurangkan persaingan kunci.

Bilakah anda harus menggunakan indeks komposit berbanding indeks lajur tunggal?Bilakah anda harus menggunakan indeks komposit berbanding indeks lajur tunggal?Apr 11, 2025 am 12:06 AM

Dalam pengoptimuman pangkalan data, strategi pengindeksan hendaklah dipilih mengikut keperluan pertanyaan: 1. Apabila pertanyaan melibatkan pelbagai lajur dan urutan syarat ditetapkan, gunakan indeks komposit; 2. Apabila pertanyaan melibatkan pelbagai lajur tetapi urutan syarat tidak ditetapkan, gunakan pelbagai indeks lajur tunggal. Indeks komposit sesuai untuk mengoptimumkan pertanyaan berbilang lajur, manakala indeks lajur tunggal sesuai untuk pertanyaan tunggal lajur.

Bagaimana untuk mengenal pasti dan mengoptimumkan pertanyaan perlahan di MySQL? (Log pertanyaan perlahan, prestasi_schema)Bagaimana untuk mengenal pasti dan mengoptimumkan pertanyaan perlahan di MySQL? (Log pertanyaan perlahan, prestasi_schema)Apr 10, 2025 am 09:36 AM

Untuk mengoptimumkan pertanyaan perlahan MySQL, SlowQuerylog dan Performance_Schema perlu digunakan: 1. Dayakan SlowQueryLog dan tetapkan ambang untuk merakam pertanyaan perlahan; 2. Gunakan Performance_Schema untuk menganalisis butiran pelaksanaan pertanyaan, cari kesesakan prestasi dan mengoptimumkan.

MySQL dan SQL: Kemahiran Penting untuk PemajuMySQL dan SQL: Kemahiran Penting untuk PemajuApr 10, 2025 am 09:30 AM

MySQL dan SQL adalah kemahiran penting untuk pemaju. 1.MYSQL adalah sistem pengurusan pangkalan data sumber terbuka, dan SQL adalah bahasa standard yang digunakan untuk mengurus dan mengendalikan pangkalan data. 2.MYSQL menyokong pelbagai enjin penyimpanan melalui penyimpanan data yang cekap dan fungsi pengambilan semula, dan SQL melengkapkan operasi data yang kompleks melalui pernyataan mudah. 3. Contoh penggunaan termasuk pertanyaan asas dan pertanyaan lanjutan, seperti penapisan dan penyortiran mengikut keadaan. 4. Kesilapan umum termasuk kesilapan sintaks dan isu -isu prestasi, yang boleh dioptimumkan dengan memeriksa penyataan SQL dan menggunakan perintah menjelaskan. 5. Teknik pengoptimuman prestasi termasuk menggunakan indeks, mengelakkan pengimbasan jadual penuh, mengoptimumkan operasi menyertai dan meningkatkan kebolehbacaan kod.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod