Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Pencarian fuzzy alamat jalan MySQL

Meskipun tidak sempurna dan bisa sangat lambat, Anda sebaiknya menggunakan ekspresi reguler melalui REGEXP().

Berikut ekspresi reguler first-pass untuk mencocokkan sebagian besar kasus (serta contoh Anda):

(?isx)                  # search across multiple lines and ignore case
(                       # full match
  (                       # st number - what about number words like one or two?
    \d+
  )
  \s+                     # whitespace
  (                       # street name (one or more words)
    [a-z]+
    (?:
      \s+
      [a-z]+
    )*
  )
  \s+                     # whitespace
  (                       # street type
    al(?:y\.?|ley)          # aly, aly. or alley
  |
    ave(?:\.|nue)?          # ave, ave., or avenue
  |
    b(?lvd\.?|oulevard)     # blvd, blvd. or boulevard
  |
    c(?:t\.?|ourt)          # ct, ct. or court
  |
    cir(?:\c\.?|cle)?       # cir, circ, circ. or circle
  |
    cres(?:\.|cent)?        # cres, cres. or crescent
  |
    dr(?:\.|ive)?           # dr, dr. or drive
  |
    exp(?:y\.?|ressway)     # expy, expy. or expressway
  |
    f(?:wy\.?|reeway)       # fwy, fwy. or freeway
  |
    g(?:rdns\.?|ardens)     # grdns, grdns. or gardens
  |
    h(?:wy\.?|ighway)       # hwy, hwy. or highway
  |
    l(?n\.?|ane)            # ln, ln. or land
  |
    m(?:nr\.?|anor)         # mnr, mnr. or manor
  |
    m(?:trwy\.?|otorway)    # mtrwy, wtrwy. or motorway
  |
    pl(?:\.|ace)?           # pl, pl. or place
  |
    r(?:d\.?|oad)           # rd, rd. or road
  |
    st(?:\.|reet)?          # st, st. or street
  |
    t(?:pk\.?|urnpike)      # tpk, tpk. or turnpike
  |
    ter(?:\r?\.?|race)      # ter, ter., terr, terr. or terrace
  |
    tr(?:l.\?|ail)          # trl, trl. or trail
  |
    pike|park|walk|loop|bay|close|gate|highlands
  |
    row|way|oval|dell|rise|vale|byway|lawn
  )
  \,?                     # optional comma
  \s+                     # whitespace
  (                       # optional number, unit, apt or floor
    (
      \#                    # number
    |
      unit                  # unit
    |
      num(?:\.|ber)         # num, num. or number
    |
      ap(?:t\.?|artment)    # apt, apt. or apartment
    |
      fl(?:\.|oor)?         # fl, fl. or floor
    )
    \s+
    \d+
  )?
)

Yang akan kembali:

$1 - pertandingan penuh

$2 - nomor rumah

$3 - nama jalan

$4 - tipe jalan

$5 - unit atau nomor apt (opsional)

Untuk menggunakan ini di mysql, Anda harus menghapus semua komentar (dari '#' ke eol), menghapus baris pertama (opsi sakelar), dan menutup semuanya menjadi satu baris tanpa spasi.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Bagaimana mengelola database MySQL, pengguna, dan tabel dari baris perintah

  2. Bagaimana cara saya memperhitungkan xPath yang hilang dan menjaga keseragaman data saya saat menggores situs web menggunakan metode kueri DOMXPath?

  3. mysqli_connect():(HY000/2002):Tidak dapat terhubung ke server MySQL lokal melalui soket

  4. Java, bagaimana cara mengubah database saat ini ke yang lain?

  5. MySQL DAYOFWEEK() - minggu saya dimulai dengan senin