发布新日志

  • 查看系统的序列号(转)

    2007-03-28 19:47:59

    1.Windows 98/Me 的序列号其实就藏在注册表中,打开 注册表编辑器 ,找到 [HKEY_LOCAL_MACHINE SoftwareMicrosoftWindowsCurrentVersion] ,而右侧窗格中 ProductKey 的值就是序列号了。


    如果 Windows 98/Me 崩溃后准备重装,却发现 Windows 的序列号找不到了,就可以使用下面方法来找系列号。用启动盘启动 系统 ,在 DOS 命令提示符后输入以下命令:

    C:WindowsCommandFind /I "ProductKey" C:Windows System.dat 回车后显示的第一行会有这样的信息: ProductKey XXXXX-XXXXX-XXXXX-XXXXX-XXXXX where the X's are your actual CD Key. 这下,你不用着急了吧。

     


    2.Windows 2000 的序列号没有在注册表里,其实在 Windows 2000 的系统文件夹的 System32 文件夹中,可以找到 $winnt$.inf 文件,直接双击用记事本打开, [userdata] 小节 “Productid=” 后面引号中的字符串,就是 Windows 2000 的序列号!


    3. 寻找 Windows XP 的安装序列号的方法更简单,打开 WindowsSystem32 ,这儿有个叫 $winnt$ 的配置文件,用 记事本 打开它,你就能找到安装序列号了。
  • 精妙SQL语句(转贴)2

    2007-03-27 12:37:27

    SQL import& export command

    EXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:\temp1.xls -c -q -S"GNETDATA/GNETDATA" -U"sa" -P""'

    /*********** 导入Excel
    SELECT *
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
    'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

    /*动态文件名
    declare @fn varchar(20),@s varchar(1000)
    set @fn = 'c:\test.xls'
    set @s ='''Microsoft.Jet.OLEDB.4.0'',
    ''Data Source="'+@fn+'";User ID=Admin;Password=;Extended properties=Excel 5.0'''
    set @s = 'SELECT * FROM OpenDataSource ('+@s+')...sheet1$'
    exec(@s)
    */

    SELECT cast(cast(科目编号 as numeric(10,2)) as nvarchar(255))+' ' 转换后的别名
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
    'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

    /********************** EXCEL导到远程SQL
    insert OPENDATASOURCE(
    'SQLOLEDB',
    'Data Source=远程ip;User ID=sa;Password=密码'
    ).库名.dbo.表名 (列名1,列名2)
    SELECT 列名1,列名2
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
    'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

    /** 导入文本文件
    EXEC master..xp_cmdshell 'bcp dbname..tablename in c:\DT.txt -c -Sservername -Usa -Ppassword'

    /** 导出文本文件
    EXEC master..xp_cmdshell 'bcp dbname..tablename out c:\DT.txt -c -Sservername -Usa -Ppassword'

    EXEC master..xp_cmdshell 'bcp "Select * from dbname..tablename" queryout c:\DT.txt -c -Sservername -Usa -Ppassword'

    导出到TXT文本,用逗号分开
    exec master..xp_cmdshell 'bcp "库名..表名" out "d:\tt.txt" -c -t ,-U sa -P password'

    BULK INSERT 库名..表名
    FROM 'c:\test.txt'
    WITH (
    FIELDTERMINATOR = ';',
    ROWTERMINATOR = '\n'
    )

    --/* dBase IV文件
    select * from
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'dBase IV;HDR=NO;IMEX=2;DATABASE=C:\','select * from [客户资料4.dbf]')
    --*/

    --/* dBase III文件
    select * from
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','select * from [客户资料3.dbf]')
    --*/

    --/* FoxPro 数据库
    select * from openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\',
    'select * from [aa.DBF]')
    --*/

    /**************导入DBF文件****************/
    select * from openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;
    SourceDB=e:\VFP98\data;
    SourceType=DBF',
    'select * from customer where country != "USA" order by country')
    go
    /***************** 导出到DBF ***************/
    如果要导出数据到已经生成结构(即现存的)FOXPRO表中,可以直接用下面的SQL语句

    insert into openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\',
    'select * from [aa.DBF]')
    select * from 表

    说明:
    SourceDB=c:\ 指定foxpro表所在的文件夹
    aa.DBF 指定foxpro表的文件名.



    /*************导出到Access********************/
    insert into openrowset('Microsoft.Jet.OLEDB.4.0',
    'x:\A.mdb';'admin';'',A表) select * from 数据库名..B表

    /*************导入Access********************/
    insert into B表 selet * from openrowset('Microsoft.Jet.OLEDB.4.0',
    'x:\A.mdb';'admin';'',A表)

    文件名为参数
    declare @fname varchar(20)
    set @fname = 'd:\test.mdb'
    exec('SELECT a.* FROM opendatasource(''Microsoft.Jet.OLEDB.4.0'',
    '''+@fname+''';''admin'';'''', topics) as a ')

    SELECT *
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
    'Data Source="f:\northwind.mdb";Jet OLEDB:Database Password=123;User ID=Admin;Password=;')...产品

    ********************* 导入 xml 文件

    DECLARE @idoc int
    DECLARE @doc varchar(1000)
    --sample XML document
    SET @doc ='
    <root>
    <Customer cid= "C1" name="Janine" city="Issaquah">
    <Order ōid="O1" date="1/20/1996" amount="3.5" />
    <Order ōid="O2" date="4/30/1997" amount="13.4">Customer was very satisfied
    </Order>
    </Customer>
    <Customer cid="C2" name="Ursula" city="Oelde" >
    <Order ōid="O3" date="7/14/1999" amount="100" note="Wrap it blue
    white red">
    <Urgency>Important</Urgency>
    Happy Customer.
    </Order>
    <Order ōid="O4" date="1/20/1996" amount="10000"/>
    </Customer>
    </root>
    '
    -- Create an internal representation of the XML document.
    EXEC sp_xml_preparedocument @idoc OUTPUT, @doc

    -- Execute a SELECT statement using OPENXML rowset provider.
    SELECT *
    FROM OPENXML (@idoc, '/root/Customer/Order', 1)
    WITH (oid char(5),
    amount float,
    comment ntext 'text()')
    EXEC sp_xml_removedocument @idoc



    ???????

    /**********************Excel导到Txt****************************************/
    想用
    select * into opendatasource(...) from opendatasource(...)
    实现将一个Excel文件内容导入到一个文本文件

    假设Excel中有两列,第一列为姓名,第二列为很行帐号(16位)
    且银行帐号导出到文本文件后分两部分,前8位和后8位分开。

    邹健:
    如果要用你上面的语句插入的话,文本文件必须存在,而且有一行:姓名,银行账号1,银行账号2
    然后就可以用下面的语句进行插入
    注意文件名和目录根据你的实际情况进行修改.

    insert into
    opendatasource('MICROSOFT.JET.OLEDB.4.0'
    ,'Text;HDR=Yes;DATABASE=C:\'
    )...[aa#txt]
    --,aa#txt)
    --*/
    select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8)
    from
    opendatasource('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;IMEX=2;DATABASE=c:\a.xls'
    --,Sheet1$)
    )...[Sheet1$]



    如果你想直接插入并生成文本文件,就要用bcp

    declare @sql varchar(8000),@tbname varchar(50)

    --首先将excel表内容导入到一个全局临时表
    select @tbname='[##temp'+cast(newid() as varchar(40))+']'
    ,@sql='select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8)
    into '+@tbname+' from
    opendatasource(''MICROSOFT.JET.OLEDB.4.0''
    ,''Excel 5.0;HDR=YES;IMEX=2;DATABASE=c:\a.xls''
    )...[Sheet1$]'
    exec(@sql)

    --然后用bcp从全局临时表导出到文本文件
    set @sql='bcp "'+@tbname+'" out "c:\aa.txt" /S"(local)" /P"" /c'
    exec master..xp_cmdshell @sql

    --删除临时表
    exec('drop table '+@tbname)

    /********************导整个数据库*********************************************/

    用bcp实现的存储过程

    /*
    实现数据导入/导出的存储过程
    根据不同的参数,可以实现导入/导出整个数据库/单个表
    调用示例:
    --导出调用示例
    ----导出单个表
    exec file2table 'zj','','','xzkh_sa..地区资料','c:\zj.txt',1
    ----导出整个数据库
    exec file2table 'zj','','','xzkh_sa','C:\docman',1

    --导入调用示例
    ----导入单个表
    exec file2table 'zj','','','xzkh_sa..地区资料','c:\zj.txt',0
    ----导入整个数据库
    exec file2table 'zj','','','xzkh_sa','C:\docman',0

    */
    if exists(select 1 from sysobjects where name='File2Table' and objectproperty(id,'IsProcedure')=1)
    drop procedure File2Table
    go
    create procedure File2Table
    @servername varchar(200) --服务器名
    ,@username varchar(200) --用户名,如果用NT验证方式,则为空''
    ,@password varchar(200) --密码
    ,@tbname varchar(500) --数据库.dbo.表名,如果不指定:.dbo.表名,则导出数据库的所有用户表
    ,@filename varchar(1000) --导入/导出路径/文件名,如果@tbname参数指明是导出整个数据库,则这个参数是文件存放路径,文件名自动用表名.txt
    ,@isout bit --1为导出,0为导入
    as
    declare @sql varchar(8000)

    if @tbname like '%.%.%' --如果指定了表名,则直接导出单个表
    begin
    set @sql='bcp '+@tbname
    +case when @isout=1 then ' out ' else ' in ' end
    +' "'+@filename+'" /w'
    +' /S '+@servername
    +case when isnull(@username,'')='' then '' else ' /U '+@username end
    +' /P '+isnull(@password,'')
    exec master..xp_cmdshell @sql
    end
    else
    begin --导出整个数据库,定义游标,取出所有的用户表
    declare @m_tbname varchar(250)
    if right(@filename,1)<>'\' set @filename=@filename+'\'

    set @m_tbname='declare #tb cursor for select name from '+@tbname+'..sysobjects where xtype=''U'''
    exec(@m_tbname)
    open #tb
    fetch next from #tb into @m_tbname
    while @@fetch_status=0
    begin
    set @sql='bcp '+@tbname+'..'+@m_tbname
    +case when @isout=1 then ' out ' else ' in ' end
    +' "'+@filename+@m_tbname+'.txt " /w'
    +' /S '+@servername
    +case when isnull(@username,'')='' then '' else ' /U '+@username end
    +' /P '+isnull(@password,'')
    exec master..xp_cmdshell @sql
    fetch next from #tb into @m_tbname
    end
    close #tb
    deallocate #tb
    end
    go

    /************* Oracle **************/
    EXEC sp_addlinkedserver 'OracleSvr',
    'Oracle 7.3',
    'MSDAORA',
    'ORCLDB'
    GO

    delete from openquery(mailser,'select * from yulin')

    select * from openquery(mailser,'select * from yulin')

    update openquery(mailser,'select * from yulin where id=15')set disorder=555,catago=888

    insert into openquery(mailser,'select disorder,catago from yulin')values(333,777)



    补充:

    对于用bcp导出,是没有字段名的.

    用openrowset导出,需要事先建好表.

    用openrowset导入,除ACCESS及EXCEL外,均不支持非本机数据导入
    删除
  • 精妙SQL语句(转贴)

    2007-03-27 12:29:38

    说明:复制表(只复制结构,源表名:a 新表名:b) 

    SQL: select * into b from a where 1<>1 

    说明:拷贝表(拷贝数据,源表名:a 目标表名:b) 

    SQL: insert into b(a, b, c) select d,e,f from b; 

    说明:显示文章、提交人和最后回复时间 

    SQL: select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b 

    说明:外连接查询(表名1:a 表名2:b) 

    SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 

    说明:日程安排提前五分钟提醒 

    SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 

    说明:两张关联表,删除主表中已经在副表中没有的信息 

    SQL: 

    delete from info where not exists ( select * from infobz where info.infid=infobz.infid ) 

    说明:-- 

    SQL: 

    SELECT A.NUM, A.NAME, B.UPD_DATE, B.PREV_UPD_DATE 

    FROM TABLE1, 

    (SELECT X.NUM, X.UPD_DATE, Y.UPD_DATE PREV_UPD_DATE 

    FROM (SELECT NUM, UPD_DATE, INBOUND_QTY, STOCK_ONHAND 

    FROM TABLE2 

    WHERE TO_CHAR(UPD_DATE,'YYYY/MM') = TO_CHAR(SYSDATE, 'YYYY/MM')) X, 

    (SELECT NUM, UPD_DATE, STOCK_ONHAND 

    FROM TABLE2 

    WHERE TO_CHAR(UPD_DATE,'YYYY/MM') = 

    TO_CHAR(TO_DATE(TO_CHAR(SYSDATE, 'YYYY/MM') || '/01','YYYY/MM/DD') - 1, 'YYYY/MM') ) Y, 

    WHERE X.NUM = Y.NUM (+) 

    AND X.INBOUND_QTY + NVL(Y.STOCK_ONHAND,0) <> X.STOCK_ONHAND ) B 

    WHERE A.NUM = B.NUM 

    说明:-- 

    SQL: 

    select * from studentinfo where not exists(select * from student where studentinfo.id=student.id) and 系名称='"&strdepartmentname&"' and 专业名称='"&strprofessionname&"' order by 性别,生源地,高考总成绩 

    说明: 

    从数据库中去一年的各单位电话费统计(电话费定额贺电化肥清单两个表来源) 

    SQL: 

    SELECT a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy') AS telyear, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '01', a.factration)) AS JAN, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '02', a.factration)) AS FRI, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '03', a.factration)) AS MAR, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '04', a.factration)) AS APR, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '05', a.factration)) AS MAY, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '06', a.factration)) AS JUE, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '07', a.factration)) AS JUL, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '08', a.factration)) AS AGU, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '09', a.factration)) AS SEP, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '10', a.factration)) AS OCT, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '11', a.factration)) AS NOV, 

    SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '12', a.factration)) AS DEC 

    FROM (SELECT a.userper, a.tel, a.standfee, b.telfeedate, b.factration 

    FROM TELFEESTAND a, TELFEE b 

    WHERE a.tel = b.telfax) a 

    GROUP BY a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy') 

    说明:四表联查问题: 

    SQL: select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ..... 

    说明:得到表中最小的未使用的ID号 

    SQL: 

    SELECT (CASE WHEN EXISTS(SELECT * FROM Handle b WHERE b.HandleID = 1) THEN MIN(HandleID) + 1 ELSE 1 END) as HandleID 

    FROM Handle 

    WHERE NOT HandleID IN (SELECT a.HandleID - 1 FROM Handle a)

    ====================================

    SQL语句技巧
    1、一个SQL语句的问题:行列转换
       select * from v_temp
    上面的视图结果如下:
    user_name role_name
    -------------------------
    系统管理员 管理员
    feng 管理员
    feng 一般用户
    test 一般用户
    想把结果变成这样:
    user_name role_name
    ---------------------------
    系统管理员 管理员
    feng 管理员,一般用户
    test 一般用户
    ===================
    create table a_test(name varchar(20),role2 varchar(20))
    insert into a_test values('李','管理員')
    insert into a_test values('張','管理員')
    insert into a_test values('張','一般用戶')
    insert into a_test values('常','一般用戶')

    create function join_str(@content varchar(100))
    returns varchar(2000)
    as
    begin
    declare @str varchar(2000)
    set @str=''
    select @str=@str+','+rtrim(role2) from a_test where [name]=@content
    select @str=right(@str,len(@str)-1)
    return @str
    end
    go

    --调用:
    select [name],dbo.join_str([name]) role2 from a_test group by [name]

    --select distinct name,dbo.uf_test(name) from a_test

    2、求助!快速比较结构相同的两表
    结构相同的两表,一表有记录3万条左右,一表有记录2万条左右,我怎样快速查找两表的不同记录?
    ============================
    给你一个测试方法,从northwind中的orders表取数据。
    select * into n1 from orders
    select * into n2 from orders

    select * from n1
    select * from n2

    --添加主键,然后修改n1中若干字段的若干条
    alter table n1 add constraint pk_n1_id primary key (OrderID)
    alter table n2 add constraint pk_n2_id primary key (OrderID)

    select OrderID from (select * from n1
    union
    select * from n2) a group by OrderID having count(*) > 1

    应该可以,而且将不同的记录的ID显示出来。
    下面的适用于双方记录一样的情况,

    select * from n1 where orderid in
    (
    select OrderID from (select * from n1
    union
    select * from n2) a group by OrderID having count(*) > 1
    )
    至于双方互不存在的记录是比较好处理的
    --删除n1,n2中若干条记录
    delete from n1 where orderID in ('10728','10730')
    delete from n2 where orderID in ('11000','11001')

    --*************************************************************
    -- 双方都有该记录却不完全相同
    select * from n1 where orderid in
    (
    select OrderID from (select * from n1
    union
    select * from n2) a group by OrderID having count(*) > 1
    )
    union
    --n2中存在但在n1中不存的在10728,10730
    select * from n1 where OrderID not in (select OrderID from n2)
    union
    --n1中存在但在n2中不存的在11000,11001
    select * from n2 where OrderID not in (select OrderID from n1)
    3.
    四种方法取表里n到m条纪录:

    1.
    select top m * into 临时表(或表变量) from tablename order by columnname -- 将top m笔插入
    set rowcount n
    select * from 表变量 order by columnname desc


    2.
    select top n * from
    (select top m * from tablename order by columnname) a
    order by columnname desc


    3.如果tablename里没有其他identity列,那么:
    select identity(int) id0,* into #temp from tablename

    取n到m条的语句为:
    select * from #temp where id0 >=n and id0 <= m

    如果你在执行select identity(int) id0,* into #temp from tablename这条语句的时候报错,那是因为你的DB中间的select into/bulkcopy属性没有打开要先执行:
    exec sp_dboption 你的DB名字,'select into/bulkcopy',true


    4.如果表里有identity属性,那么简单:
    select * from tablename where identitycol between n and m
    5.如何删除一个表中重复的记录?
    create table a_dist(id int,name varchar(20))

    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')

    exec up_distinct 'a_dist','id'

    select * from a_dist

    create procedure up_distinct(@t_name varchar(30),@f_key varchar(30))
    --f_key表示是分組字段﹐即主鍵字段
    as
    begin
    declare @max integer,@id varchar(30) ,@sql varchar(7999) ,@type integer
    select @sql = 'declare cur_rows cursor for select '+@f_key+' ,count(*) from ' +@t_name +' group by ' +@f_key +' having count(*) > 1'
    exec(@sql)
    open cur_rows
    fetch cur_rows into @id,@max
    while @@fetch_status=0
    begin
    select @max = @max -1
    set rowcount @max
    select @type = xtype from syscolumns where id=object_id(@t_name) and name=@f_key
    if @type=56
    select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+ @id
    if @type=167
    select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+''''+ @id +''''
    exec(@sql)
    fetch cur_rows into @id,@max
    end
    close cur_rows
    deallocate cur_rows
    set rowcount 0
    end

    select * from systypes
    select * from syscolumns where id = object_id('a_dist')

    6.查询数据的最大排序问题(只能用一条语句写)
    CREATE TABLE hard (qu char (11) ,co char (11) ,je numeric(3, 0))

    insert into hard values ('A','1',3)
    insert into hard values ('A','2',4)
    insert into hard values ('A','4',2)
    insert into hard values ('A','6',9)
    insert into hard values ('B','1',4)
    insert into hard values ('B','2',5)
    insert into hard values ('B','3',6)
    insert into hard values ('C','3',4)
    insert into hard values ('C','6',7)
    insert into hard values ('C','2',3)


    要求查询出来的结果如下:

    qu co je
    ----------- ----------- -----
    A 6 9
    A 2 4
    B 3 6
    B 2 5
    C 6 7
    C 3 4


    就是要按qu分组,每组中取je最大的前2位!!
    而且只能用一句sql语句!!!
    select * from hard a where je in (select top 2 je from hard b where a.qu=b.qu order by je)
    7.求删除重复记录的sql语句?
    怎样把具有相同字段的纪录删除,只留下一条。
    例如,表test里有id,name字段
    如果有name相同的记录 只留下一条,其余的删除。
    name的内容不定,相同的记录数不定。
    有没有这样的sql语句?
    ==============================
    A:一个完整的解决方案:

    将重复的记录记入temp1表:
    select [标志字段id],count(*) into temp1 from [表名]
    group by [标志字段id]
    having count(*)>1

    2、将不重复的记录记入temp1表:
    insert temp1
    select [标志字段id],count(*) from [表名]
    group by [标志字段id]
    having count(*)=1

    3、作一个包含所有不重复记录的表:
    select * into temp2 from [表名]
    where 标志字段id in(select 标志字段id from temp1)

    4、删除重复表:
    delete [表名]

    5、恢复表:
    insert [表名]
    select * from temp2

    6、删除临时表:
    drop table temp1
    drop table temp2
    ================================
    B:
    create table a_dist(id int,name varchar(20))

    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')
    insert into a_dist values(1,'abc')

    exec up_distinct 'a_dist','id'

    select * from a_dist

    create procedure up_distinct(@t_name varchar(30),@f_key varchar(30))
    --f_key表示是分組字段﹐即主鍵字段
    as
    begin
    declare @max integer,@id varchar(30) ,@sql varchar(7999) ,@type integer
    select @sql = 'declare cur_rows cursor for select '+@f_key+' ,count(*) from ' +@t_name +' group by ' +@f_key +' having count(*) > 1'
    exec(@sql)
    open cur_rows
    fetch cur_rows into @id,@max
    while @@fetch_status=0
    begin
    select @max = @max -1
    set rowcount @max
    select @type = xtype from syscolumns where id=object_id(@t_name) and name=@f_key
    if @type=56
    select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+ @id
    if @type=167
    select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+''''+ @id +''''
    exec(@sql)
    fetch cur_rows into @id,@max
    end
    close cur_rows
    deallocate cur_rows
    set rowcount 0
    end

    select * from systypes
    select * from syscolumns where id = object_id('a_dist')

     

  • C语言学习--经典例题

    2007-03-26 16:27:59

    【典型示例】

    【例1】计算两个数的最大公约数; 分析:首先,随机输入两个数mn(默认m>n);其次,算法:使km除以n的余数,如果m能被n整除,则k值为0n为这两个数的最大公约数,否则,使k代替nn代替m,重复以上过程,直到k值为0

    #include"stdio.h"

    main()

    {

    int m,n,k,result;

    printf("Enter two numbers:");

    scanf("%d,%d",&m,&n);

    if(m>0&&n>0) /*限定两个正整数*/

    {

    do

    {

    k=n%m;

    if(k= =0)

    result=m;

    else

    {

    n=m;

    m=k;

    }

    }while(k>0); /*循环取余求出最大公因子*/

    printf("The greatest common divistor is:%d\n",result);

    }

    else printf("Nonpositive values not allowed\n");

    }

    【例2】用牛顿迭代求方程2x3-4x2+3x-6=01.0附近的根。

    #include “math.h”

    main()

    {

    float x,x0,f,f1;

    x=1.0;

    do

    { x0=x;

    f=((2*x0-4)*x0+3)*x0-6;

    f1=(6*x0-8)*x0+3;

    x=x0-f/f1;

    }

    while(fabs(x-x0)>=1e-5);

    printf(“%6.2f”,x);

    }

    【例3】打印下列图案

    *

    ***

    *****

    *******

    main()

    { int i,j;

    for(i=1; i<=4;i++)

    {for(j=1;j<= 4-i;j++)

    printf(“ ”);

    for(j=1;j<=2*i-1;j++)

    printf(“*”);

    printf(“\n”);

    }

    }

    【例4】判断m是否是素数。

    程序:

    #include <math.h>

    main()

    {

    int m,i,k;

    scanf(“%d”,&m);

    k=sqrt(m+1);

    for(i=2;i<=k;i++)

    if (m%i= =0)

    break;

    if(i>=k+1)

    printf(“%d is a prime number\n”,m);

    else

    printf(“%d is not a prime number\n”,m);

    }

  • C语言学习--循环语句

    2007-03-26 16:27:48

    求和s= 3+33+333

    main()

    {

    int s=0,t=3,i;

    for(i=1;i<=3;i++)

    {

         s=s+t;

         t=10*t+3;

      }

      printf(“%d”,s);

    }

    说明:对于初始化了变量(ab),虽然自增变量(i++)没有参与算式(s=s+tt=10*t+3)中的运算,但算式(s=s+tt=10*t+3)还是会自增运算,即:循环体每循环一次,都会以之前的循环时得到的值的基础上,按算式(s=s+tt=10*t+3)累加计算;直到循环结束。
  • C语言学习--直接插入排序法

    2007-03-24 15:15:39

    插入排序(Insertion Sort)的基本思想是:每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子文件中的适当位置,直到全部记录插入完成为止。
         本节介绍两种插入排序方法:直接插入排序和希尔排序。

    直接插入排序基本思想

    1、基本思想

         假设待排序的记录存放在数组R[1..n]中。初始时,R[1]自成1个有序区,无序区为R[2..n]。从i=2起直至i=n为止,依次将R[i]插入当前的有序区R[1..i-1]中,生成含n个记录的有序区。

    2、第i-1趟直接插入排序:
         通常将一个记录R[i](i=2,3,…,n-1)插入到当前的有序区,使得插入后仍保证该区间里的记录是按关键字有序的操作称第i-1趟直接插入排序。
         排序过程的某一中间时刻,R被划分成两个子区间R[1..i-1](已排好序的有序区)和R[i..n](当前未排序的部分,可称无序区)。
         直接插入排序的基本操作是将当前无序区的第1个记录R[i]插人到有序区R[1..i-1]中适当的位置上,使R[1..i]变为新的有序区。因为这种方法每次使有序区增加1个记录,通常称增量法。
         插入排序与打扑克时整理手上的牌非常类似。摸来的第1张牌无须整理,此后每次从桌上的牌(无序区)中摸最上面的1张并插入左手的牌(有序区)中正确的位置上。为了找到这个正确的位置,须自左向右(或自右向左)将摸来的牌与左手中已有的牌逐一比较。

    一趟直接插入排序方法

    1.简单方法

         首先在当前有序区R[1..i-1]中查找R[i]的正确插入位置k(1≤k≤i-1);然后将R[k..i-1]中的记录均后移一个位置,腾出k位置上的空间插入R[i]。
      注意:
         若R[i]的关键字大于等于R[1..i-1]中所有记录的关键字,则R[i]就是插入原位置。

    2.改进的方法
      一种查找比较操作和记录移动操作交替地进行的方法。
    具体做法:
         将待插入记录R[i]的关键字从右向左依次与有序区中记录R[j](j=i-1,i-2,…,1)的关键字进行比较:
         ① 若R[j]的关键字大于R[i]的关键字,则将R[j]后移一个位置;
          ②若R[j]的关键字小于或等于R[i]的关键字,则查找过程结束,j+1即为R[i]的插入位置。
         关键字比R[i]的关键字大的记录均已后移,所以j+1的位置已经腾空,只要将R[i]直接插入此位置即可完成一趟直接插入排序。

    直接插入排序算法

    1.算法描述

      void lnsertSort(SeqList R)
       { //对顺序表R中的记录R[1..n]按递增序进行插入排序
        int i,j;
        for(i=2;i<=n;i++) //依次插入R[2],…,R[n]
          if(R[i].key<R[i-1].key){//若R[i].key大于等于有序区中所有的keys,则R[i]
                                  //应在原有位置上
            R[0]=R[i];j=i-1; //R[0]是哨兵,且是R[i]的副本
            do{ //从右向左在有序区R[1..i-1]中查找R[i]的插入位置
             R[j+1]=R[j]; //将关键字大于R[i].key的记录后移
             j-- ;
             }while(R[0].key<R[j].key); //当R[i].key≥R[j].key时终止
            R[j+1]=R[0]; //R[i]插入到正确的位置上
           }//endif
       }//InsertSort

    2.哨兵的作用
         算法中引进的附加记录R[0]称监视哨或哨兵(Sentinel)。
         哨兵有两个作用:
      ① 进人查找(插入位置)循环之前,它保存了R[i]的副本,使不致于因记录后移而丢失R[i]的内容;
      ② 它的主要作用是:在查找循环中"监视"下标变量j是否越界。一旦越界(即j=0),因为R[0].key和自己比较,循环判定条件不成立使得查找循环结束,从而避免了在该循环内的每一次均要检测j是否越界(即省略了循环判定条件"j>=1")。
      注意:
       ① 实际上,一切为简化边界条件而引入的附加结点(元素)均可称为哨兵。
        【例】单链表中的头结点实际上是一个哨兵
      ② 引入哨兵后使得测试查找循环条件的时间大约减少了一半,所以对于记录数较大的文件节约的时间就相当可观。对于类似于排序这样使用频率非常高的算法,要尽可能地减少其运行时间。所以不能把上述算法中的哨兵视为雕虫小技,而应该深刻理解并掌握这种技巧。

    给定输入实例的排序过程

         设待排序的文件有8个记录,其关键字分别为:49,38,65,97,76,13,27,49。为了区别两个相同的关键字49,后一个49的下方加了一下划线以示区别。其排序过程见【动画模拟演示

    算法分析

    1.算法的时间性能分析 

         对于具有n个记录的文件,要进行n-1趟排序。
        各种状态下的时间复杂度:
    ┌─────────┬─────┬──────┬──────┐
    │ 初始文件状态     │   正序   │     反序   │无序(平均)  │
    ├─────────┼─────┼──────┼──────┤
    │ 第i趟的关键      │   1      │     i+1    │ (i-2)/2  │
    │ 字比较次数       │          │            │            │
    ├─────────┼─────┼──────┼──────┤
    │总关键字比较次数  │   n-1    │(n+2)(n-1)/2│ ≈n2/4     │
    ├─────────┼─────┼──────┼──────┤
    │第i趟记录移动次数 │   0      │ i+2        │ (i-2)/2  │
    ├─────────┼─────┼──────┼──────┤
    │总的记录移动次数  │   0      │(n-1)(n+4)/2│ ≈n2/4     │
    ├─────────┼─────┼──────┼──────┤
    │时间复杂度        │  0(n)  │ O(n2)    │ O(n2)    │
    └─────────┴─────┴──────┴──────┘
    注意:
         初始文件按关键字递增有序,简称"正序"。
         初始文件按关键字递减有序,简称"反序"。

    2.算法的空间复杂度分析
         算法所需的辅助空间是一个监视哨,辅助空间复杂度S(n)=O(1)。是一个就地排序。

    3.直接插入排序的稳定性
         直接插入排序是稳定的排序方法。

  • C语言学习--冒泡排序法

    2007-03-24 15:01:17

    交换排序的基本思想是:两两比较待排序记录的关键字,发现两个记录的次序相反时即进行交换,直到没有反序的记录为止。
         应用交换排序基本思想的主要排序方法有:冒泡排序和快速排序。

    冒泡排序

    1、排序方法

         将被排序的记录数组R[1..n]垂直排列,每个记录R[i]看作是重量为R[i].key的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。
    (1)初始
         R[1..n]为无序区。

    (2)第一趟扫描
         从无序区底部向上依次比较相邻的两个气泡的重量,若发现轻者在下、重者在上,则交换二者的位置。即依次比较(R[n],R[n-1]),(R[n-1],R[n-2]),…,(R[2],R[1]);对于每对气泡(R[j+1],R[j]),若R[j+1].key<R[j].key,则交换R[j+1]和R[j]的内容。
         第一趟扫描完毕时,"最轻"的气泡就飘浮到该区间的顶部,即关键字最小的记录被放在最高位置R[1]上。

    (3)第二趟扫描

         扫描R[2..n]。扫描完毕时,"次轻"的气泡飘浮到R[2]的位置上……
         最后,经过n-1 趟扫描可得到有序区R[1..n]
      注意:
         第i趟扫描时,R[1..i-1]和R[i..n]分别为当前的有序区和无序区。扫描仍是从无序区底部向上直至该区顶部。扫描完毕时,该区中最轻气泡飘浮到顶部位置R[i]上,结果是R[1..i]变为新的有序区。

    2、冒泡排序过程示例
         对关键字序列为49 38 65 97 76 13 27 49的文件进行冒泡排序的过程【参见动
    Flash: 冒泡排序法
    画演示


    3、排序算法
    (1)分析
         因为每一趟排序都使有序区增加了一个气泡,在经过n-1趟排序之后,有序区中就有n-1个气泡,而无序区中气泡的重量总是大于等于有序区中气泡的重量,所以整个冒泡排序过程至多需要进行n-1趟排序。
         若在某一趟排序中未发现气泡位置的交换,则说明待排序的无序区中所有气泡均满足轻者在上,重者在下的原则,因此,冒泡排序过程可在此趟排序后终止。为此,在下面给出的算法中,引入一个布尔量exchange,在每趟排序开始前,先将其置为FALSE。若排序过程中发生了交换,则将其置为TRUE。各趟排序结束时检查exchange,若未曾发生过交换则终止算法,不再进行下一趟排序。

    (2)具体算法

      void BubbleSort(SeqList R)
       { //R(l..n)是待排序的文件,采用自下向上扫描,对R做冒泡排序
         int i,j;
         Boolean exchange; //交换标志
         for(i=1;i<n;i++){ //最多做n-1趟排序
           exchange=FALSE; //本趟排序开始前,交换标志应为假
           for(j=n-1;j>=i;j--) //对当前无序区R[i..n]自下向上扫描
            if(R[j+1].key<R[j].key){//交换记录
              R[0]=R[j+1]; //R[0]不是哨兵,仅做暂存单元
              R[j+1]=R[j];
              R[j]=R[0];
              exchange=TRUE; //发生了交换,故将交换标志置为真
             }
           if(!exchange) //本趟排序未发生交换,提前终止算法
                 return;
         } //endfor(外循环)
        } //BubbleSort

    4、算法分析
    (1)算法的最好时间复杂度
         若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数C和记录移动次数M均达到最小值:
            Cmin=n-1
            Mmin=0。
         冒泡排序最好的时间复杂度为O(n)。

    (2)算法的最坏时间复杂度

         若初始文件是反序的,需要进行n-1趟排序。每趟排序要进行n-i次关键字的比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:
            Cmax=n(n-1)/2=O(n2)
            Mmax=3n(n-1)/2=O(n2)
         冒泡排序的最坏时间复杂度为O(n2)。

    (3)算法的平均时间复杂度为O(n2)

         虽然冒泡排序不一定要进行n-1趟,但由于它的记录移动次数较多,故平均时间性能比直接插入排序要差得多。

    (4)算法稳定性

         冒泡排序是就地排序,且它是稳定的。

    5、算法改进
         上述的冒泡排序还可做如下的改进:
    (1)记住最后一次交换发生位置lastExchange的冒泡排序
      在每趟扫描中,记住最后一次交换发生的位置lastExchange,(该位置之前的相邻记录均已有序)。下一趟排序开始时,R[1..lastExchange-1]是有序区,R[lastExchange..n]是无序区。这样,一趟排序可能使当前有序区扩充多个记录,从而减少排序的趟数。具体算法【参见习题】。

    (2) 改变扫描方向的冒泡排序
     ①冒泡排序的不对称性
      能一趟扫描完成排序的情况:
         只有最轻的气泡位于R[n]的位置,其余的气泡均已排好序,那么也只需一趟扫描就可以完成排序。
    【例】对初始关键字序列12,18,42,44,45,67,94,10就仅需一趟扫描。
    需要n-1趟扫描完成排序情况:
         当只有最重的气泡位于R[1]的位置,其余的气泡均已排好序时,则仍需做n-1趟扫描才能完成排序。
    【例】对初始关键字序列:94,10,12,18,42,44,45,67就需七趟扫描。
     
    ②造成不对称性的原因
      每趟扫描仅能使最重气泡"下沉"一个位置,因此使位于顶端的最重气泡下沉到底部时,需做n-1趟扫描。

  • C语言学习--选择排序法

    2007-03-07 09:00:23

    选择排序(Selection Sort)的基本思想是:每一趟从待排序的记录中选出关键字最小的记录,顺序放在已排好序的子文件的最后,直到全部记录排序完毕。
         常用的选择排序方法有直接选择排序和堆排序。

    直接选择排序(Straight Selection Sort)

    1、直接选择排序的基本思想

         n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果:
     ①初始状态:无序区为R[1..n],有序区为空。
     ②第1趟排序
         在无序区R[1..n]中选出关键字最小的记录R[k],将它与无序区的第1个记录R[1]交换,使R[1..1]和R[2..n]分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。
      ……
     ③第i趟排序
      第i趟排序开始时,当前有序区和无序区分别为R[1..i-1]和R[i..n](1≤i≤n-1)。该趟排序从当前无序区中选出关键字最小的记录R[k],将它与无序区的第1个记录R[i]交换,使R[1..i]和R[i+1..n]分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。
         这样,n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果。

    2、直接选择排序的过程
      对初始关键字为49、38、65、97、76、13、27和49的文件进行直接选择排序的过程

    3、算法描述
      直接选择排序的具体算法如下:
     void SelectSort(SeqList R)
     {
       int i,j,k;
       for(i=1;i<n;i++){//做第i趟排序(1≤i≤n-1)
         k=i;
         for(j=i+1;j<=n;j++) //在当前无序区R[i..n]中选key最小的记录R[k]
           if(R[j].key<R[k].key)
             k=j; //k记下目前找到的最小关键字所在的位置
           if(k!=i){ //交换R[i]和R[k]
             R[0]=R[i];R[i]=R[k];R[k]=R[0]; //R[0]作暂存单元
            } //endif
         } //endfor
      } //SeleetSort

    4、算法分析
    (1)关键字比较次数
         无论文件初始状态如何,在第i趟排序中选出最小关键字的记录,需做n-i次比较,因此,总的比较次数为:
         n(n-1)/2=0(n2)

    (2)记录的移动次数
         当初始文件为正序时,移动次数为0
         文件初态为反序时,每趟排序均要执行交换操作,总的移动次数取最大值3(n-1)。
         直接选择排序的平均时间复杂度为O(n2)。

    (3)直接选择排序是一个就地排序

    (4)稳定性分析
         直接选择排序是不稳定的
  • 界面设计规范

    2007-03-07 08:49:55

    界面是软件与用户交互的最直接的层,界面的好坏决定用户对软件的第一印象。设计良好的界面能够引导用户自己完成相应操作,起到向导作用。

    界面设计主要是为了达到以下目的:

    1)        以用户为中心。设计由用户控制的界面,而不是界面控制用户。

    2)        清楚一致的设计。所有界面的风格保持一致,所有具有相同含义的术语保持一致,且易于理解和使用。

    3)        拥有良好的直觉特征。以用户所熟悉的现实世界事务的抽象来给用户暗示和隐喻,来帮助用户能迅速学会软件的使用。

    4)        较快的响应速度。

    5)        简洁、美观。

    以下规则应该重视:

    界面风格一致性

    操作项

    基本规范

    UI色彩与字体

    1)  UI 字体,色彩要一致。

    2)  整体色彩搭配要融为一体,同时诸如CaptionButton 起提示、提交作用的部分要清楚,醒目。

    3)  不可修改的字段,统一使用灰色文字显示。(例:浏览页面、删除页面均需显示灰色)

    窗口风格

    1)  所有窗口最大化、最小化风格要一致。

    2)  报错页面的风格一致,最好有统一的报错页面。

    3)  类似功能的窗口打开的风格要一致。

    4)  相同功能在不同模块的名称要一致。

    5)  子窗体应尽量在显示在主窗体的左上或居中放置。

    6)  弹出式窗口应尽量在不借助水平和垂直滚动条的情况下显示所有内容。

    7)  窗体支持最小化和最大化或放大时,窗体上的控件也要随着窗体而缩放;不能只放大窗体而忽略控件的缩放。

    8)  父窗体支持缩放时,子窗体不必缩放。

    9)  实现自定义界面风格(可参考电子社区系统)

    布局与间距(待定)

    1)  窗体控件布局和间距尽量与Windows标准保持一致。

    2)  按钮与窗体上、下、左、右之间的间距为

    3)  按钮之间的间距为

    4)  ……

    菜单深度

    1)  菜单深度一般不要超过三层

    2)  菜单层次太多时,应给出返回主窗口、主分支的快捷链接。

       

    1)  按钮风格相同,大小相似,标题字体保持一致,在整个系统中的显示位置要统一。

    2)  无效按钮要屏蔽。

       

    1)  复选框和选项框按选择几率的高低而先后排列。

    2)  复选框和选项框要有默认选项,并支持Tab选择。

    3)  界面空间较小时使用下拉框而不用选择框。

    4)  选项数较少时使用选项框,相反使用下拉列表框。

    文本框输入

    操作项

    基本规范

    1)必输项中不可为空,不可输入空格

    2)必输项给出必输项标识(*)。

    3)非必输项字段,Null 插入数据库时不会出错,在数据库中设置默认值。

    字段长度

    超过数据库规定长度时不允许输入,自动截断超长部分(注:2字符=1字)

    格式校验

    1)身份证号、E-MAIL、邮箱等特定字段的格式要符合需求的规定。

    日期格式

    1)  日期显示格式一致,为 yyyy-mm-dd

    2)  使用日期控件,则不可手工录入。

    3)  若允许手工输入:需做格式校验。不可输入字符串、汉字、特殊字符。

    4)  若允许手工输入:对于日期段,需在截止日期小于开始日期时给出提示。

    特殊字符

    1)输入区域输入特殊字符,插入数据库时不出错或提示不允许输入特殊字符。特殊字符包括: “ = <df>  @  `  ~  $  %  ^  % & #  @

    英文输入

    英文输入不区分大小写,不可输入汉字、数字及特殊字符

    数值字段

    只能输入+ ,— 0~9及功能键(BackSpace 光标) 。数值不能为负数。

    字符字段

    字符字段中只能输入字符,非法字符如单引号、数字均不可输入

    单行文本框/多行文本框

    1)        长度合适,可以容纳相应文字,但不能超过数据库该字段长度,最好将可以输入的最大字符数标在旁边。建议单行文本框中当输入的字符超过一定长度时再输入无效;对于多行文本框给出最大字符数标识

    附件

    1)  可正常添加符合格式的附件。

    2)  附件可正常打开和保存,附件名较长时可正常操作。

    3)  直接输入错误的附件地址,保存时应给出提示信息。

    4)  附件打开和保存到本地时,文件名要显示原文件的文件名。

    密码输入

    1)  需在需求中定义密码是否允许为空或空格;密码是否允许特殊字符;是否区分大小写,密码的可输入长度。

    2)  程序中应给出文字说明密码的可输入长度。

    用户界面行为

    操作项

    基本规范

       

    1)鼠标为不可点击状态时显示箭头,可点击状态显示手型;系统忙时显示沙漏形状

    光标定位

    1)  打开新增(修改)页面时,光标初始定位在第一个待输入的文本区

    2)  因输入不正确提示用户重新输入时,光标默认focus在出错的输入区,并高亮全选该错误输入。

    3)  若必输项未填写完毕就提交,应给出说明信息并能自动获得焦点;

    4)  可写控件检测到非法输入后应给出说明并能自动获得焦点

    TAB

    1)  界面支持键盘自动浏览按钮功能。即TAB的自动切换功能。

    查看(825) 评论(0) 收藏 分享 管理

    我的存档

    数据统计

    • 访问量: 6734
    • 日志数: 9
    • 建立时间: 2007-03-02
    • 更新时间: 2007-03-28

    RSS订阅