走过路过不要错过!望有经验兄台分享一下。
一个关于用户注册和查询的问题。如果说我这个系统有一千万个用户我不用一个表存这么多用户。
多建一些用户表每一个用户表存一万个用户这样就需要一千个表。
当用户登录时从一万个数据里面查找和从一千万个数据里面查找速度必然不同。
但是我怎么能够知道这个用户在一千个用户表当中哪一个表里面呢?
如果可以快速的知道在哪个表里面一条查询语句就可以判断密码是否正确登录成功与否了!
用户注册时只要满足6-18位字母数字下划线组合而且数据库里面没有就可以注册成功。
但是从一千个用户表里面用ajax验证用户是否存在也是一个考验!这里我应该怎么设计呢?
这个和申请qq号还不一样qq号是腾讯给的所以完全可以知道这个号段在哪个表里面。
望各位兄台有经验的分享一下。万分感谢!蓝色字迹两个问题希望大家帮忙出出主意。
回复讨论(解决方案)
字母数字加下划线共有 37 种首字符,如果区分大小写则有 63 种(不过数据库字符串比较是不区分大小写的,需指定为二进制方式才会区分)
取前两位做键,则 37 * 37 = 1369,已经能满足你 一千个表 表的设想了
//设用户名为$username = 'abcd';//构造表名$tbl_name = 'U' . substr($username, 0, 2);//则查询串为$srl = "select * from $tbl_name where username='$username'";
你需要再单独建一个索引表,表里面记录各个表中用户的排序情况。检索的时候只要先检索这个表,定位用户所在的范围,然后再检索那个表就可以了。
你需要再单独建一个索引表,表里面记录各个表中用户的排序情况。检索的时候只要先检索这个表,定位用户所在的范围,然后再检索那个表就可以了。
这位兄台的思路也是我最先想到的但是我感觉这样还要查询两次数据库可不可以查询一次数据库呢?
字母数字加下划线共有 37 种首字符,如果区分大小写则有 63 种(不过数据库字符串比较是不区分大小写的,需指定为二进制方式才会区分)
取前两位做键,则 37 * 37 = 1369,已经能满足你 一千个表 表的设想了
//设用户名为$username = 'abcd';//构造表名$tbl_name = 'U' . substr($username, 0, 2);//则查询串为$srl = "select * from $tbl_name where username='$username'";
恩,兄台的这个思路确实给了我指引而且是一个很好而高效的方案。
那如果说我的表名是从user1一直到user1000命名的。那我应该怎么定位用户在哪个表里呢?
那就是自找麻烦了。
你需要另建一张表,用于存储分表信息。查询时先查这张表,取得真实存放的表名
而这张表依然是存放着以什么字符串开头的在什么表中
那就是自找麻烦了。
你需要另建一张表,用于存储分表信息。查询时先查这张表,取得真实存放的表名
而这张表依然是存放着以什么字符串开头的在什么表中
我也感觉表名如果用user1到user1000来命名确实很难操作。
2楼兄台思路可行不过要查询两次。
还有没有其他有经验的兄台进来分享一下

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Alipay Php ...

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Artikel ini membincangkan menambah fungsi khusus kepada kerangka kerja, memberi tumpuan kepada pemahaman seni bina, mengenal pasti titik lanjutan, dan amalan terbaik untuk integrasi dan debugging.

Menghantar data JSON menggunakan perpustakaan Curl PHP dalam pembangunan PHP, sering kali perlu berinteraksi dengan API luaran. Salah satu cara biasa ialah menggunakan perpustakaan curl untuk menghantar post ...
