易截截图软件、单文件、免安装、纯绿色、仅160KB

SQL 判断身份证号码

现要求查询界面:不论15位或者18位身份证号都能查询出数据库中所有当前用户信息。
方案1:
create or replace function CONVERT_ID_15 (/*转换身份证号为15位*/
  p_id2 in varchar2
) return varchar2
is
  p_id varchar2(20);
  id varchar2(15);
begin
  p_id:=ltrim(p_id2);
  p_id:=rtrim(p_id);
  if length(p_id) = 18 then
    id:=substr(p_id, 1, 6) || substr(p_id, 9, 9);
  else
    id:=substr(p_id, 1, 15);
  end if;
  return id;
exception
  when others then
    return null;
end
;
//delphi
 s:=s + ' and CONVERT_ID_15(hf_id) = ''' + ConvertID15(edHf_id.Text) + '''';
方案2:
在代码端 把输入的身份证号统一截成15位,然后格式化成'430221%850924382%'
//15位身份证类似成18位   注意要先转成15位
function hf_id18(id15:String):String;
var
id18:String;
begin
     if length(id15) = 15 then
      begin
        id18:=copy(id15,0,6)+'%'+copy(id15,7,9)+'%';
      end
      else
      begin
        id18:= id15;
      end;
        result:=id18;
end;
 SQL:=SQL+' AND YQ_IDCARD like ''' + CardIdNew+'''';
查询速度甚至比方案一还稍快。


相关文档:

ORACLE PL/SQL 集合学习笔记(二)

三、嵌套表的使用方法
 
1、将嵌套表定义为PL/SQL的程序构造块
 
TYPE type_name IS TABLE OF element_type[NOT NULL];
 
如下例所示:
DECLARE

-- Define a nested table of variable length strings.
TYPE card_table IS TABLE OF VARCHAR2(5 CHAR);

-- Declare and initialize a n ......

SQL Explorer QT4.5 配置MySQL ODBC和MySQL驱动

 QT DataBase SQL Explorer
1、安装MySQL到官方网站下载MySQL数据库,非安装版,直接运行mysqld进程前台的
2、添加系统环境变量,Path+=':\mysql\bin'的path,再在开始运行,CMD->mysql -uroot 登录到mySQL数据库
   Default password没有的,有的话 mysql -uroot -p输入密码;网络登录:mysql -h ip ......

高性能网站建设之 MS Sql Server数据库分区

什么是数据库分区?
数据库分区是一种对表的横向分割,Sql server 2005企业版和之后的Sql server版本才提供这种技术,这种对表的横向分割不同于2000中的表分割,它对访问用户是透明的,用户并不会感觉的表被横向分割了。(2000中的表横向分割是建n个表例如按时间建表每月一个表,表名不同,最后需要做一个大视图)
关于具 ......

动态创建Sql Server数据库相关(全)

 
CREATE DATABASE
创建一个新数据库及存储该数据库的文件,或从先前创建的数据库的文件中附加数据库。
说明 有关与 DISK INIT 向后兼容性的更多信息,请参见"Microsoft® SQL Server™ 向后兼容性详细信息"中的设备(级别 3)。
语法
CREATE DATABASE database_name
[ ON
[ < filespec > ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号