जैसे स्कीमा के बारे में क्या है
CREATE TABLE employee
(
employeeid INT PRIMARY KEY AUTO_INCREMENT,
firstname varchar(255)
);
CREATE INDEX part_of_firstname ON employee (firstname(4));
इससे आप अपनी प्राकृतिक प्राथमिक कुंजी का उपयोग करके काफी तेज़ी से लुकअप कर पाएंगे, साथ ही आपको कृत्रिम प्राथमिक कुंजी भी देंगे और असामान्य करने के लिए बाध्य नहीं करेंगे।
EXPLAIN SELECT * FROM EMPLOYEE WHERE EMPLOYEEID = 1 AND FIRSTNAME LIKE 'john%';
+----+-------------+----------+-------+---------------------------+---------+---------+-------+------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+----------+-------+---------------------------+---------+---------+-------+------+-------+
| 1 | SIMPLE | employee | const | PRIMARY,part_of_firstname | PRIMARY | 4 | const | 1 | |
+----+-------------+----------+-------+---------------------------+---------+---------+-------+------+-------+
बेशक चूंकि प्राथमिक कुंजी का 0001 भाग उपयोगकर्ता की पहचान करने के लिए पर्याप्त अद्वितीय है, इसलिए आपको नाम से बिल्कुल भी पूछताछ करने की आवश्यकता नहीं है।
यदि आप पूर्व-गणना करने पर जोर देते हैं तो यह काम करना चाहिए
CREATE TABLE employee
(
employeeid INT PRIMARY KEY AUTO_INCREMENT,
specialid VARCHAR(255),
firstname VARCHAR(255)
);
CREATE INDEX employee_specialid ON employee (firstname(4));
DELIMITER ;;
CREATE TRIGGER employeeid_trigger BEFORE insert ON employee
FOR EACH ROW
BEGIN
SET new.specialid = CONCAT(LPAD((SELECT AUTO_INCREMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE() AND TABLE_NAME = 'employee'), 4, '0'), SUBSTRING(new.firstname, 1, 4));
END
;;
DELIMITER ;
इसका परीक्षण करना:
mysql> insert into employee (firstname) values ('johnathan');
Query OK, 1 row affected (0.04 sec)
mysql> insert into employee (firstname) values ('johnathan');
Query OK, 1 row affected (0.02 sec)
mysql> insert into employee (firstname) values ('johnathan');
Query OK, 1 row affected (0.02 sec)
mysql> select * from employee;
+------------+-----------+-----------+
| employeeid | specialid | firstname |
+------------+-----------+-----------+
| 1 | 0001john | johnathan |
| 2 | 0002john | johnathan |
| 3 | 0003john | johnathan |
+------------+-----------+-----------+
3 rows in set (0.00 sec)
यह एक तरह का हैक है, और कुछ ऐसे डीबी पर info_schema उपलब्ध नहीं होगा जहां अनुमतियां आपके नियंत्रण में नहीं हैं।