通过SQL校验身份证号码是否正确
根据提供的身份证号码信息验证身份证号码是否符合二代身份证规范,其中区域编码网上可下载。
使用数据库为DB2,但目测可以通用身份证号码第18位验证算法从网上查得,具体验证算法如下:
1、将前面的身份证号码17位数分别乘以不同的系数。第i位对应的数为[2^(18-i)]mod11。从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ;
2、将这17位数字和系数相乘的结果相加;
3、用加出来和除以11,看余数是多少?;
4、余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2;
<无>
相关mysql视频教程推荐:《mysql教程》
select /*pspt_id为用户身份证号码*/ a.pspt_id /*判断用户身份证是否符合规则*/ ,case /*判断身份证号码是否为18位*/ when length(a.pspt_id)<>'18' then '身份证号码位数不对' /*判断身份证号码前17位是否含除数字外的字符*/ when translate(substr(a.pspt_id,1,17),'','0123456789') <>'' then '身份证号码前17位格式不正确' /*判断身份证的年份是否在合理范围内*/ when substr(a.pspt_id,7,4) not between '1900' and '2014' then '身份证年份错误' /*判断身份证的月份是否在合理范围内*/ when substr(a.pspt_id,11,2) not between '01' and '12' then '身份证月份错误' /*判断身份证日期是否在合理范围内*/ when substr(a.pspt_id,13,2) not between 1 and day(to_date(char(substr(a.pspt_id,7,4)||'-'||substr(a.pspt_id,11,2)||'-01',10),'yyyy-mm-dd')+1 month-1 day) then '身份证日期错误' /*判断身份证号码的第18位是否符合验证规则*/ when mod(( substr(a.pspt_id,1,1)*7+ substr(a.pspt_id,2,1)*9+ substr(a.pspt_id,3,1)*10+ substr(a.pspt_id,4,1)*5+ substr(a.pspt_id,5,1)*8+ substr(a.pspt_id,6,1)*4+ substr(a.pspt_id,7,1)*2+ substr(a.pspt_id,8,1)*1+ substr(a.pspt_id,9,1)*6+ substr(a.pspt_id,10,1)*3+ substr(a.pspt_id,11,1)*7+ substr(a.pspt_id,12,1)*9+ substr(a.pspt_id,13,1)*10+ substr(a.pspt_id,14,1)*5+ substr(a.pspt_id,15,1)*8+ substr(a.pspt_id,16,1)*4+ substr(a.pspt_id,17,1)*2 ),11) <> ( case when substr(a.pspt_id,18,1)='1' then '0' when substr(a.pspt_id,18,1)='0' then '1' when substr(a.pspt_id,18,1) in ('X','x') then '2' when substr(a.pspt_id,18,1)='9' then '3' when substr(a.pspt_id,18,1)='8' then '4' when substr(a.pspt_id,18,1)='7' then '5' when substr(a.pspt_id,18,1)='6' then '6' when substr(a.pspt_id,18,1)='5' then '7' when substr(a.pspt_id,18,1)='4' then '8' when substr(a.pspt_id,18,1)='3' then '9' when substr(a.pspt_id,18,1)='2' then '10' end ) then '身份证验证错误' /*判断身份证号码的区域编码是否符合规则*/ when b.county_sar_code is null then '区县编码校验错误' else '有效实名制客户' end /*用户信息表,包含所需要查询的身份证号码信息*/ from usr_info a /*身份证的行政区域编码表,从统计局官网和网上可以下载,设定county_sar_code为6位行政编码*/ left join csounty_sar b on substr(a.pspt_id,1,6)=b.county_sar_code

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

Une carte d'identité ne peut ouvrir qu'un seul magasin Taobao. Les vendeurs doivent respecter les réglementations de la plateforme Taobao et ne pas essayer d'utiliser les cartes d'identité d'autres personnes pour ouvrir plusieurs magasins. Les vendeurs peuvent développer leur activité et augmenter leurs ventes en fusionnant des magasins et en ouvrant des succursales. Il convient toutefois de noter que chaque succursale doit utiliser une carte d'identité indépendante pour l'authentification par nom réel.

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? L'agrégation des données et les statistiques sont des étapes très importantes lors de l'analyse des données et des statistiques. En tant que puissant système de gestion de bases de données relationnelles, MySQL fournit une multitude de fonctions d'agrégation et de statistiques, qui peuvent facilement effectuer des opérations d'agrégation de données et de statistiques. Cet article présentera la méthode d'utilisation des instructions SQL pour effectuer l'agrégation de données et les statistiques dans MySQL, et fournira des exemples de code spécifiques. 1. Utilisez la fonction COUNT pour compter. La fonction COUNT est la plus couramment utilisée.
