Rumah pangkalan data tutorial mysql oracle判断汉字和全角字符的方法

oracle判断汉字和全角字符的方法

Jun 07, 2016 pm 03:39 PM
oracle lebar penuh penghakiman unit watak kaedah watak Cina

最近由于单位提了一个需求,要判断提供的用户名称里不有全角字符,至少有两个汉字。找了半天,想通过正则表达式来解决,但测试了好久才发现,oracle的正则函数REGEXP_LIKE 不支持“\un匹配 n,其中 n 是以四位十六进制数表示的 Unicode 字符”的判断,例如,

最近由于单位提了一个需求,要判断提供的用户名称里不有全角字符,至少有两个汉字。找了半天,想通过正则表达式来解决,但测试了好久才发现,oracle的正则函数REGEXP_LIKE 不支持“\un 匹配 n,其中 n 是以四位十六进制数表示的 Unicode 字符”的判断,例如,\u00A9 匹配版权符号 (?),而标准的正则是可以支持的,所以这个办法行不通,只能过期其他办法来实现。

在网上找了半天,都没有确切的实现办法,有通过Length()和lengthb ()来判断,但不完美,所以就把自己的写法记录下来希望能有用处。

对于全角字符,ascii值的范围是\uFF00-\uFFFF,都是FF段的,所以可以通过转换成ascii 来判断,instr(asciistr(replace( '在《<23\', '\')),'\FF',1,1) > 0 就可以实现

对于汉字,范围太大,只能通过函数来完成,于是写了如下函数:

create or replace function get_chinese(v_name in varchar2) return integer is
  i       int;
  v_count integer;
  v_code  varchar2(10);
begin
  v_count := 0;
  /**

  作者:背包去流浪

  QQ:380140243

  用途:   返回字符串中汉字的个数
  原理说明:  因为汉字的ASCII码值在4E00和9FA5之间,所以,可以将字符串转为ASCII后,判断连续的5位是否在这个范围,
  是则为汉字,否则为其他字符。
  返回值:    汉字个数
  异常返回:  -1
   */
  for i in 1 .. lengthb(asciistr(v_name)) - 4 loop 
    --if substr(asciistr(v_name),i,1)='\' then --有\则判断是否汉字
    v_code := substr(asciistr(v_name), i, 5);
    IF V_CODE BETWEEN '\4E00' AND '\9FA5' THEN
      --汉字的asciid码值范围
      v_count := v_count + 1; --有一个汉字
    end if;
    -- dbms_output.put_line(v_code);
  -- end if;
  end loop;
  return v_count;
exception
  when others then
    return - 1; --异常返回-1
end get_chinese;
 查询结果:

 oracle判断汉字和全角字符的方法

Kenyataan Laman Web ini
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

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 lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara mengkonfigurasi pembolehubah persekitaran di oracle Cara mengkonfigurasi pembolehubah persekitaran di oracle Apr 11, 2025 pm 07:18 PM

Panduan Konfigurasi Pembolehubah Alam Sekitar Oracle: Buat pembolehubah persekitaran Oracle_Home, menunjuk ke direktori rumah Oracle. Tambah direktori binari oracle ke pembolehubah persekitaran jalan. Tetapkan pembolehubah persekitaran TNS_ADMIN (jika fail dinamakan menggunakan TNS). Sahkan tetapan pembolehubah persekitaran untuk memastikan output memaparkan pembolehubah set.

Cara menambah medan meja ke oracle Cara menambah medan meja ke oracle Apr 11, 2025 pm 07:30 PM

Gunakan pernyataan ALTER Jadual, sintaks khusus adalah seperti berikut: alter table table_name Tambah column_name data_type [kekangan-klausa]. Di mana: Table_name adalah nama jadual, column_name adalah nama medan, data_type adalah jenis data, dan kekangan-fasal adalah kekangan pilihan. Contoh: Alter Table Pekerja menambah e -mel varchar2 (100) Tambahkan medan e -mel ke jadual pekerja.

Cara menyampaikan semula oracle Cara menyampaikan semula oracle Apr 11, 2025 pm 07:33 PM

Oracle menyediakan pelbagai kaedah pertanyaan deduplikasi: Kata kunci yang berbeza mengembalikan nilai yang unik untuk setiap lajur. Kumpulan oleh klausa mengumpulkan hasil dan mengembalikan nilai tidak berulang bagi setiap kumpulan. Kata kunci yang unik digunakan untuk membuat indeks yang mengandungi hanya baris unik, dan pertanyaan indeks akan secara automatik deduplicate. Fungsi row_number () memberikan nombor unik dan menapis hasil yang mengandungi hanya baris 1. Min () atau max () mengembalikan nilai tidak berulang dari lajur angka. Operator Intersect mengembalikan nilai -nilai bersama kedua -dua set hasil (tiada pendua).

Cara mengimport pangkalan data oracle Cara mengimport pangkalan data oracle Apr 11, 2025 pm 08:06 PM

Kaedah Import Data: 1. Gunakan utiliti SQLLoader: Sediakan fail data, buat fail kawalan, dan jalankan SQLLoader; 2. Gunakan alat IMP/EXP: data eksport, data import. Petua: 1. Disyorkan SQL*loader untuk set data besar; 2. Jadual sasaran harus wujud dan perlawanan definisi lajur; 3. Selepas mengimport, integriti data perlu disahkan.

Cara menyelesaikan kod gadbled di oracle Cara menyelesaikan kod gadbled di oracle Apr 11, 2025 pm 10:09 PM

Masalah Garbled Oracle boleh diselesaikan dengan memeriksa set aksara pangkalan data untuk memastikan ia sepadan dengan data. Tetapkan set aksara klien untuk memadankan pangkalan data. Tukar data atau ubah suai set aksara lajur untuk memadankan set aksara pangkalan data. Gunakan set aksara Unicode dan elakkan set aksara multibyte. Semak bahawa tetapan bahasa pangkalan data dan pelanggan betul.

Cara menggunakan prosedur tersimpan untuk oracle Cara menggunakan prosedur tersimpan untuk oracle Apr 11, 2025 pm 07:03 PM

Prosedur yang disimpan adalah satu set pernyataan SQL yang boleh disimpan dalam pangkalan data dan boleh dipanggil berulang kali sebagai unit berasingan. Mereka boleh menerima parameter (dalam, keluar, inout) dan memberikan kelebihan penggunaan semula kod, keselamatan, prestasi dan modulariti. Contoh: Buat prosedur yang disimpan CALLULATE_SUM untuk mengira jumlah dua nombor dan simpannya dalam parameter OUT.

Cara memeriksa saiz meja oracle Cara memeriksa saiz meja oracle Apr 11, 2025 pm 08:15 PM

Untuk menanyakan saiz ruang meja oracle, ikuti langkah -langkah berikut: Tentukan nama meja dengan menjalankan pertanyaan: pilih Tablespace_Name dari DBA_TableSpaces; Tanya saiz meja dengan menjalankan pertanyaan: pilih jumlah (bait) sebagai total_size, jumlah (bytes_free) sebagai tersedia_space, jumlah (bytes) - jumlah (bytes_free) sebagai digunakan_space dari dba_data_files di mana tablespace_

Cara Membuat Kekangan Utama Utama di Oracle Cara Membuat Kekangan Utama Utama di Oracle Apr 11, 2025 pm 07:15 PM

Kunci utama adalah lajur khas atau gabungan lajur yang secara unik mengenal pasti setiap baris dalam jadual. Ia memastikan bahawa rekod dalam jadual adalah unik dan boleh dibuat dengan: menentukan nama jadual menggunakan pernyataan Alter Table. Tambah kata kunci utama utama diikuti dengan nama lajur untuk menentukan sebagai kunci utama. Kekangan utama utama membantu memastikan keunikan data, meningkatkan kelajuan pertanyaan, mencegah rekod pendua dan memudahkan jadual gabungan.

See all articles