作者姓名: AlbertLam

老爸日記

JetJet的一份不容易完成的親子功課

JetJet的一份不容易完成的親子功課!剛看到這份功課時第一反應是什麼世道哎,這是小朋友適合的功課嗎?本想做來意義不大,就擱置了好幾天,直至老師催交、孩子他媽怨罵,兒子也催了,無奈還得要做。家里光線不好,不想影響孩子視力,於是上網買了一盞3M的據說可保視力的枱燈,就等今天交收即用。果然效果不錯,還算對得起付出的720大元。將枱燈開處後立即與兒子一起“研討”如何創作這份功課,結論是將JetJet喜歡的東西放進畫面,構成符合主題要求的作品。上網找了一些所需元素的圖片作參考,先在稿紙上畫草圖,然後正式在功課紙上畫正稿,這才發現荒廢了幾十年的畫筆拿在手中是那麼的不聽使,畫出的線條與想像中的效果相差太遠,真成了眼高手底的實例了。最後,一幅小學生都可以完成的作品卻花了幾個小時才成了這樣像半成品的粗劣畫作!功多手才熟是很有道理的,平時不練習,臨急抱佛腳是不成滴!

[caption id="attachment_621" align="aligncenter" width="614"] 創作工具[/caption]
老爸日記

嬤嬤牛一,JET是主角~

今天是嬤嬤的牛一,但真正的主角卻成了JETJET。一家大細逛了大半天商場想送嬤嬤一份生日禮物,但嬤嬤都舍不得花錢而以各種借口拒絕最終沒送出。相反,嬤嬤倒是送了份禮物給JETJET,付錢毫不猶豫一點也不吝啬。蛋糕都是JETJET揀選的 Angry Birds。哎,天下父母心,都是為了下一代而無私付出、任勞任怨。所以,孝敬父母、尊重他們是每一個為人子女都必需做到的基本責任,而無論他們是一個怎麼樣的人。特別是也已為人父母的時侯,更加身同感受。而且,還要行孝及時,不要待他日深悔時才感悟“樹欲靜而風不止,子欲養而親不待”的道理,那可為時已晚了。

[gallery link="file"]
老爸日記

精妙的SQL语句

说明:复制表(只复制结构,源表名:a 新表名:b)
select * into b from a where 1<>1

 

说明:拷贝表(拷贝数据,源表名:a 目标表名:b)
insert into b(a, b, c) select d,e,f from b;

 

说明:显示文章、提交人和最后回复时间
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)
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c

 

说明:日程安排提前五分钟提醒
select * from 日程安排 where datediff(‘minute’,f开始时间,getdate())>5

 

说明:两张关联表,删除主表中已经在副表中没有的信息
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

 

说明:–
select * from studentinfo where not exists(select * from student where studentinfo.id=student.id) and 系名称='”&strdepartmentname&”‘ and 专业名称='”&strprofessionname&”‘ order by 性别,生源地,高考总成绩
从数据库中去一年的各单位电话费统计(电话费定额贺电化肥清单两个表来源)

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’)

 

说明:四表联查问题
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号
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语句的问题:行列转换
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
快速比较结构相同的两表
结构相同的两表,一表有记录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)
四种方法取表里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
如何删除一个表中重复的记录?
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’)
查询数据的最大排序问题(只能用一条语句写)
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)
求删除重复记录的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’)
行列转换–普通

假设有张学生成绩表(CJ)如下
Name Subject Result
张三 语文 80
张三 数学 90
张三 物理 85
李四 语文 85
李四 数学 92
李四 物理 82

想变成
姓名 语文 数学 物理
张三 80 90 85
李四 85 92 82

declare @sql varchar(4000)
set @sql = ‘select Name’
select @sql = @sql + ‘,sum(case Subject when ”’+Subject+”’ then Result end) [‘+Subject+’]’
from (select distinct Subject from CJ) as a
select @sql = @sql+’ from test group by name’
exec(@sql)

行列转换–合并

有表A,
id pid
1 1
1 2
1 3
2 1
2 2
3 1
如何化成表B:
id pid
1 1,2,3
2 1,2
3 1

创建一个合并的函数
create function fmerg(@id int)
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str=”
select @str=@str+’,’+cast(pid as varchar) from 表A where id=@id
set @str=right(@str,len(@str)-1)
return(@str)
End
go

–调用自定义函数得到结果
select distinct id,dbo.fmerg(id) from 表A
如何取得一个数据表的所有列名

方法如下:先从SYSTEMOBJECT系统表中取得数据表的SYSTEMID,然后再SYSCOLUMN表中取得该数据表的所有列名。
SQL语句如下:
declare @objid int,@objname char(40)
set @objname = ‘tablename’
select @objid = id from sysobjects where id = object_id(@objname)
select ‘Column_name’ = name from syscolumns where id = @objid order by colid

Select * FROM INFORMATION_SCHEMA.COLUMNS Where TABLE_NAME =’users’
通过SQL语句来更改用户的密码

修改别人的,需要sysadmin role
EXEC sp_password NULL, ‘newpassword’, ‘User’

如果帐号为SA执行EXEC sp_password NULL, ‘newpassword’, sa
怎么判断出一个表的哪些字段不允许为空?

select COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS where IS_NULLABLE=’NO’ and TABLE_NAME=tablename
如何在数据库里找到含有相同字段的表?
a. 查已知列名的情况
Select b.name as TableName,a.name as columnname
From syscolumns a INNER JOIN sysobjects b
ON a.id=b.id
AND b.type=’U’
AND a.name=’你的字段名字’
未知列名查所有在不同表出现过的列名
Select o.name As tablename,s1.name As columnname
From syscolumns s1, sysobjects o
Where s1.id = o.id
And o.type = ‘U’
And Exists (
Select 1 From syscolumns s2
Where s1.name = s2.name
And s1.id <> s2.id
)
查询第xxx行数据

假设id是主键:
select * from (select top xxx * from yourtable) aa where not exists(select 1 from (select top xxx-1 * from yourtable) bb where aa.id=bb.id)

如果使用游标也是可以的
fetch absolute [number] from [cursor_name]
行数为绝对行数
SQL Server日期计算
a. 一个月的第一天
Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
b. 本周的星期一
Select DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)
c. 一年的第一天
Select DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
d. 季度的第一天
Select DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
e. 上个月的最后一天
Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
f. 去年的最后一天
Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
g. 本月的最后一天
Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
h. 本月的第一个星期一
select DATEADD(wk, DATEDIFF(wk,0,
dateadd(dd,6-datepart(day,getdate()),getdate())
), 0)
i. 本年的最后一天
Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。
获取表结构[把 ‘sysobjects’ 替换 成 ‘tablename’ 即可]

Select CASE IsNull(I.name, ”)
When ” Then ”
Else ‘*’
End as IsPK,
Object_Name(A.id) as t_name,
A.name as c_name,
IsNull(SubString(M.text, 1, 254), ”) as pbc_init,
T.name as F_DataType,
CASE IsNull(TYPEPROPERTY(T.name, ‘Scale’), ”)
WHEN ” Then Cast(A.prec as varchar)
ELSE Cast(A.prec as varchar) + ‘,’ + Cast(A.scale as varchar)
END as F_Scale,
A.isnullable as F_isNullAble
FROM Syscolumns as A
JOIN Systypes as T
ON (A.xType = T.xUserType AND A.Id = Object_id(‘sysobjects’) )
LEFT JOIN ( SysIndexes as I
JOIN Syscolumns as A1
ON ( I.id = A1.id and A1.id = object_id(‘sysobjects’) and (I.status & 0x800) = 0x800 AND A1.colid <= I.keycnt) )
ON ( A.id = I.id AND A.name = index_col(‘sysobjects’, I.indid, A1.colid) )
LEFT JOIN SysComments as M
ON ( M.id = A.cdefault and ObjectProperty(A.cdefault, ‘IsConstraint’) = 1 )
orDER BY A.Colid ASC
提取数据库内所有表的字段详细说明的SQL语句

Select
(case when a.colorder=1 then d.name else ” end) N’表名’,
a.colorder N’字段序号’,
a.name N’字段名’,
(case when COLUMNPROPERTY( a.id,a.name,’IsIdentity’)=1 then ‘√’else ”
end) N’标识’,
(case when (Select count(*)
FROM sysobjects
Where (name in
(Select name
FROM sysindexes
Where (id = a.id) AND (indid in
(Select indid
FROM sysindexkeys
Where (id = a.id) AND (colid in
(Select colid
FROM syscolumns
Where (id = a.id) AND (name = a.name))))))) AND
(xtype = ‘PK’))>0 then ‘√’ else ” end) N’主键’,
b.name N’类型’,
a.length N’占用字节数’,
COLUMNPROPERTY(a.id,a.name,’PRECISION’) as N’长度’,
isnull(COLUMNPROPERTY(a.id,a.name,’Scale’),0) as N’小数位数’,
(case when a.isnullable=1 then ‘√’else ” end) N’允许空’,
isnull(e.text,”) N’默认值’,
isnull(g.[value],”) AS N’字段说明’
FROM syscolumns a
left join systypes b
on a.xtype=b.xusertype
inner join sysobjects d
on a.id=d.id and d.xtype=’U’ and d.name<>’dtproperties’
left join syscomments e
on a.cdefault=e.id
left join sysproperties g
on a.id=g.id AND a.colid = g.smallid
order by object_name(a.id),a.colorder
快速获取表test的记录总数[对大容量表非常有效]

快速获取表test的记录总数:
select rows from sysindexes where id = object_id(‘test’) and indid in (0,1)

update 2 set KHXH=(ID+1)2 2行递增编号
update [23] set id1 = ‘No.’+right(‘00000000’+id,6) where id not like ‘No%’ //递增
update [23] set id1= ‘No.’+right(‘00000000’+replace(id1,’No.’,”),6) //补位递增
delete from [1] where (id%2)=1
奇数
替换表名字段
update [1] set domurl = replace(domurl,’Upload/Imgswf/’,’Upload/Photo/’) where domurl like ‘%Upload/Imgswf/%’
截位
Select LEFT(表名, 5)

老爸日記

SQL中的join的详细用法!inner join,full outer join,left join,right jion

‘–查询分析器中执行:

–建表table1,table2:

create table table1(id int,name varchar(10))

create table table2(id int,score int)

insert into table1 select 1,’lee’

insert into table1 select 2,’zhang’

insert into table1 select 4,’wang’

insert into table2 select 1,90

insert into table2 select 2,100

insert into table2 select 3,70

如表

————————————————-

table1         |        table2

————————————————-

id    name     |   id     score

1      lee        |    1       90

2     zhang   |    2      100

4      wang    |    3        70

————————————————-

以下均在查询分析器中执行

一、外连接

1.概念:包括左向外联接、右向外联接或完整外部联接

2.左连接:left join 或 left outer join

(1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。

(2)sql语句

select * from table1 left join table2 on table1.id=table2.id

————-结果————-

id name   id    score

——————————

1   lee       1       90

2   zhang   2      100

4   wang    NULL NULL

——————————

注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

3.右连接:right join 或 right outer join

(1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

(2)sql语句

select * from table1 right join table2 on table1.id=table2.id

————-结果————-

id      name     id     score

——————————

1       lee        1      90

2      zhang      2      100

NULL NULL      3      70

——————————

注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

4.完整外部联接:full join 或 full outer join

(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

(2)sql语句

select * from table1 full join table2 on table1.id=table2.id

————-结果————-

id      name      id      score

——————————

1      lee            1      90

2       zhang       2      100

4      wang      NULL NULL

NULL NULL      3      70

——————————

注释:返回左右连接的和(见上左、右连接)

二、内连接

1.概念:内联接是用比较运算符比较要联接列的值的联接

2.内连接:join 或 inner join

3.sql语句

select * from table1 join table2 on table1.id=table2.id

————-结果————-

id   name   id       score

——————————

1       lee      1           90

2       zhang 2          100

——————————

注释:只返回符合条件的table1和table2的列

4.等价(与下列执行效果相同)

A:select a.*,b.* from table1 a,table2 b where a.id=b.id

B:select * from table1 cross join table2 where table1.id=table2.id (注:cross join后加条件只能用where,不能用on)

三、交叉连接(完全)

1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)

2.交叉连接:cross join (不带条件where…)

3.sql语句

select * from table1 cross join table2

————-结果————-

id         name       id         score

——————————

1          lee            1            90

2          zhang         1          90

4            wang         1            90

1            lee             2            100

2            zhang         2            100

4            wang           2            100

1            lee              3            70

2            zhang          3            70

4            wang           3            70

——————————

注释:返回3*3=9条记录,即笛卡尔积

4.等价(与下列执行效果相同)

A:select * from table1,table2

另说:mysql不支持full join

老爸日記

经典MYSQL语句

SQL分类:
DDL—数据定义语言(Create,Alter,Drop,DECLARE)
DML—数据操纵语言(Select,Delete,Update,Insert)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
首先,简要介绍基础语句:
1、说明:创建数据库
Create DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
— 创建 备份数据的 device
USE master
EXEC sp_addumpdevice ‘disk’, ‘testBack’, ‘c:mssql7backupMyNwind_1.dat’
— 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、说明:删除新表
drop table tabname
6、说明:增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
8、说明:创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、说明:创建视图:create view viewname as select statement
删除视图:drop view viewname
10、说明:几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ —like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
11、说明:几个高级查询运算词
A: UNION 运算符
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、说明:使用外连接
A、left outer join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
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
B:right outer join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full outer join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
其次,大家来看一些不错的sql语句
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)
法一:select * into b from a where 1<>1
法二:select top 0 * into b from a
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
insert into b(a, b, c) select d,e,f from b;
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件
例子:..from b in ‘”&Server.MapPath(“.”)&”data.mdb” &”‘ where..
4、说明:子查询(表名1:a 表名2:b)
select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)
5、说明:显示文章、提交人和最后回复时间
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b
6、说明:外连接查询(表名1:a 表名2:b)
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
7、说明:在线视图查询(表名1:a )
select * from (Select a,b,c FROM a) T where t.a > 1;
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括
select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2
9、说明:in 的使用方法
select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)
10、说明:两张关联表,删除主表中已经在副表中没有的信息
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )
11、说明:四表联查问题:
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 …..
12、说明:曰程安排提前五分钟提醒
SQL: select * from 曰程安排 where datediff(‘minute’,f开始时间,getdate())>5
13、说明:一条sql 语句搞定数据库分页
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段
14、说明:前10条记录
select top 10 * form table1 where 范围
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表
(select a from tableA ) except (select a from tableB) except (select a from tableC)
17、说明:随机取出10条数据
select top 10 * from tablename order by newid()
18、说明:随机选择记录
select newid()
19、说明:删除重复记录
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,…)
20、说明:列出数据库里所有的表名
select name from sysobjects where type=’U’
21、说明:列出表里的所有的
select name from syscolumns where id=object_id(‘TableName’)
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。
select type,sum(case vender when ‘A’ then pcs else 0 end),sum(case vender when ‘C’ then pcs else 0 end),sum(case vender when ‘B’ then pcs else 0 end) FROM tablename group by type
显示结果:
type vender pcs
电脑 A 1
电脑 A 1
光盘 B 2
光盘 A 2
手机 B 3
手机 C 3
23、说明:初始化表table1
TRUNCATE TABLE table1
24、说明:选择从10到15的记录
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc

随机选择数据库记录的方法(使用Randomize函数,通过SQL语句实现)
对存储在数据库中的数据来说,随机数特性能给出上面的效果,但它们可能太慢了些。你不能要求ASP“找个随机数”然后打印出来。实际上常见的解决方案是建立如下所示的循环:
Randomize
RNumber = Int(Rnd*499) +1

While Not objRec.EOF
If objRec(“ID”) = RNumber THEN
… 这里是执行脚本 …
end if
objRec.MoveNext
Wend

这 很容易理解。首先,你取出1到500范围之内的一个随机数(假设500就是数据库内记录的总数)。然后,你遍历每一记录来测试ID 的值、检查其是否匹配RNumber。满足条件的话就执行由THEN 关键字开始的那一块代码。假如你的RNumber 等于495,那么要循环一遍数据库花的时间可就长了。虽然500这个数字看起来大了些,但相比更为稳固的企业解决方案这还是个小型数据库了,后者通常在一 个数据库内就包含了成千上万条记录。这时候不就死定了?
采用SQL,你就可以很快地找出准确的记录并且打开一个只包含该记录的recordset,如下所示:
Randomize
RNumber = Int(Rnd*499) + 1

SQL = “Select * FROM Customers Where ID = ” & RNumber

set objRec = ObjConn.Execute(SQL)
Response.WriteRNumber & ” = ” & objRec(“ID”) & ” ” & objRec(“c_email”)

不必写出RNumber 和ID,你只需要检查匹配情况即可。只要你对以上代码的工作满意,你自可按需操作“随机”记录。Recordset没有包含其他内容,因此你很快就能找到你需要的记录这样就大大降低了处理时间。
再谈随机数
现在你下定决心要榨干Random 函数的最后一滴油,那么你可能会一次取出多条随机记录或者想采用一定随机范围内的记录。把上面的标准Random 示例扩展一下就可以用SQL应对上面两种情况了。
为了取出几条随机选择的记录并存放在同一recordset内,你可以存储三个随机数,然后查询数据库获得匹配这些数字的记录:
SQL = “Select * FROM Customers Where ID = ” & RNumber & ” or ID = ” & RNumber2 & ” or ID = ” & RNumber3

假如你想选出10条记录(也许是每次页面装载时的10条链接的列表),你可以用BETWEEN 或者数学等式选出第一条记录和适当数量的递增记录。这一操作可以通过好几种方式来完成,但是 Select 语句只显示一种可能(这里的ID 是自动生成的号码):
SQL = “Select * FROM Customers Where ID BETWEEN ” & RNumber & ” AND ” & RNumber & “+ 9”
注意:以上代码的执行目的不是检查数据库内是否有9条并发记录。

随机读取若干条记录,测试过
Access语法:Select top 10 * From 表名 orDER BY Rnd(id)
Sql server语法:select top n * from 表名 order by newid()
MySql语法:Select * From 表名 order By rand() Limit n
Access左连接语法(最近开发要用左连接,Access帮助什么都没有,网上没有Access的SQL说明,只有自己测试, 现在记下以备后查)
语法:Select table1.fd1,table1,fd2,table2.fd2 From table1 left join table2 on table1.fd1,table2.fd1 where …
使用SQL语句 用…代替过长的字符串显示
语法:
SQL数据库:select case when len(field)>10 then left(field,10)+’…’ else field end as news_name,news_id from tablename
Access数据库:Select iif(len(field)>2,left(field,2)+’…’,field) FROM tablename;

Conn.Execute说明
Execute方法
该方法用于执行SQL语句。根据SQL语句执行后是否返回记录集,该方法的使用格式分为以下两种:
1.执行SQL查询语句时,将返回查询得到的记录集。用法为:
Set 对象变量名=连接对象.Execute(“SQL 查询语言”)
Execute方法调用后,会自动创建记录集对象,并将查询结果存储在该记录对象中,通过Set方法,将记录集赋给指定的对象保存,以后对象变量就代表了该记录集对象。

2.执行SQL的操作性语言时,没有记录集的返回。此时用法为:
连接对象.Execute “SQL 操作性语句” [, RecordAffected][, Option]
·RecordAffected 为可选项,此出可放置一个变量,SQL语句执行后,所生效的记录数会自动保存到该变量中。通过访问该变量,就可知道SQL语句队多少条记录进行了操作。
·Option 可选项,该参数的取值通常为adCMDText,它用于告诉ADO,应该将Execute方法之后的第一个字符解释为命令文本。通过指定该参数,可使执行更高效。
·BeginTrans、RollbackTrans、CommitTrans方法
这三个方法是连接对象提供的用于事务处理的方法。BeginTrans用于开始一个事物;RollbackTrans用于回滚事务;CommitTrans用于提交所有的事务处理结果,即确认事务的处理。
事务处理可以将一组操作视为一个整体,只有全部语句都成功执行后,事务处理才算成功;若其中有一个语句执行失败,则整个处理就算失败,并恢复到处里前的状态。
BeginTrans 和CommitTrans用于标记事务的开始和结束,在这两个之间的语句,就是作为事务处理的语句。判断事务处理是否成功,可通过连接对象的Error集 合来实现,若Error集合的成员个数不为0,则说明有错误发生,事务处理失败。Error集合中的每一个Error对象,代表一个错误信息。

老爸日記

PHP常用代码大全(新手入门必备)

1、连接MYSQL数据库代码
<?php
$connec=mysql_connect(“localhost”,”root”,”root”) or die(“不能连接数据库服务器: “.mysql_error());
mysql_select_db(“liuyanben”,$connec) or die (“不能选择数据库: “.mysql_error());
mysql_query(“set names ‘gbk'”);
?>

2、读取数据库,并实现循环输出
<?php
$sql=”select * from liuyan order by ly_id desc”;
$conn=mysql_query($sql,$connec);
while($rs=mysql_fetch_array($conn)){
?>
循环的内容………
<?php
}
?>

3、如何实现分页,包括两个函数,两个调用
1)两个函数
<?
//分页函数
function genpage(&$sql,$page_size=2)
{
global $prepage,$nextpage,$pages,$sums; //out param
$page = $_GET[“page”];
$eachpage = $page_size;
$pagesql = strstr($sql,” from “);
$pagesql = “select count(*) as ids “.$pagesql;
$conn = mysql_query($pagesql) or die(mysql_error());
if($rs = mysql_fetch_array($conn)) $sums = $rs[0];
$pages = ceil(($sums-0.5)/$eachpage)-1;
$pages = $pages>=0?$pages:0;
$prepage = ($page>0)?$page-1:0;
$nextpage = ($page<$pages)?$page+1:$pages;
$startpos = $page*$eachpage;
$sql .=” limit $startpos,$eachpage “;
}
// 显示分页
function showpage()
{
global $page,$pages,$prepage,$nextpage,$queryString; //param from genpage function
$shownum =10/2;
$startpage = ($page>=$shownum)?$page-$shownum:0;
$endpage = ($page+$shownum<=$pages)?$page+$shownum:$pages;

echo “共”.($pages+1).”页: “;
if($page>0)echo “<a href=$PHP_SELF?page=0$queryString>首页</a>”;
if($startpage>0)
echo ” … <b><a href=$PHP_SELF?page=”.($page-$shownum*2).”$queryString>?</a></b>”;
for($i=$startpage;$i<=$endpage;$i++)
{
if($i==$page) echo ” <b>[“.($i+1).”]</b> “;
else echo ” <a href=$PHP_SELF?page=$i$queryString>”.($i+1).”</a> “;
}
if($endpage<$pages)
echo “<b><a href=$PHP_SELF?page=”.($page+$shownum*2).”$queryString>?</a></b> … “;
if($page<$pages)
echo “<a href=$PHP_SELF?page=$pages$queryString>尾页</a>”;
}
//显示带分类的分页
function showpage1()
{
$fenlei=$_GET[“fenleiid”];
global $page,$pages,$prepage,$nextpage,$queryString; //param from genpage function
$shownum =10/2;
$startpage = ($page>=$shownum)?$page-$shownum:0;
$endpage = ($page+$shownum<=$pages)?$page+$shownum:$pages;

echo “共”.($pages+1).”页: “;
if($page>0)echo “<a href=$PHP_SELF?fenleiid=$fenlei&page=0$queryString>首页</a>”;
if($startpage>0)
echo ” … <b><a href=$PHP_SELF?fenleiid=$fenlei&page=”.($page-$shownum*2).”$queryString>?</a></b>”;
for($i=$startpage;$i<=$endpage;$i++)
{
if($i==$page) echo ” <b>[“.($i+1).”]</b> “;
else echo ” <a href=$PHP_SELF?fenleiid=$fenlei&page=$i$queryString>”.($i+1).”</a> “;
}
if($endpage<$pages)
echo “<b><a href=$PHP_SELF?fenleiid=$fenlei&page=”.($page+$shownum*2).”$queryString>?</a></b> … “;
if($page<$pages)
echo “<a href=$PHP_SELF?fenleiid=$fenlei&page=$pages$queryString>尾页</a& amp; gt;”;
}
?>
2)两个调用
第一个
<?php
$sql=”select * from liuyan order by ly_id desc”;
genpage($sql); //只需要正常代码加上这一行就ok。
$conn=mysql_query($sql,$connec);
while($rs=mysql_fetch_array($conn)){
?>
第二个
<?php
}
?>
<?php
showpage(); //显示页
?>
<?php
mysql_close();
?>

4、服务器端包含
<?php require_once(‘conn.php’); ?>

5、如何将一条记录写入数据库,然后提示并跳转页面
<?php
$ly_title=$_POST[“ly_title”];
$ly_content=$_POST[“ly_content”];
$ly_time=$_POST[“ly_time”];
$ly_author=$_POST[“ly_author”];
$ly_email=$_POST[“ly_email”];
$sql=”insert into liuyan(ly_title,ly_content,ly_time,ly_author,ly_email) values(‘”.$ly_title.”‘,'”.$ly_content.”‘,'”.$ly_time.”‘,'”.$ly_author.”‘,'”.$ly_email.”‘)”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘添加成功!’);location.href=’index.php’;</script>”);
?>

6、 弹出对话框,并发生页面跳转
<?php
echo(“<script type=’text/javascript’> alert(‘添加成功!’);location.href=’index.php’;</script>”);
?>

7、 信息查看页面(有条件读取数据库)
1)有条件读取数据库
<?php
$sql=”select * from liuyan where ly_id=$_GET[id]”;
$conn=mysql_query($sql,$connec);
$rs=mysql_fetch_array($conn);
?>
2) 将某个字段输出
<?=$rs[ly_title]?>
3)关闭数据库
<?php
mysql_close();
?>

8、对数据库中某一条记录进行更新操作,并作提示跳转
<?php
$ly_title=$_POST[“ly_title”];
$ly_content=$_POST[“ly_content”];
$ly_time=$_POST[“ly_time”];
$ly_author=$_POST[“ly_author”];
$ly_email=$_POST[“ly_email”];
$sql=”update liuyan set ly_title=’$ly_title’,ly_content=’$ly_content’,ly_time=’$ly_time’,ly_author=’$ly_author’,ly_email=’$ly_email’ where ly_id=$_GET[id]”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘更新成功!’);location.href=’../index.php’;</script>”);
?>

9、 如何删除数据库中的一条记录
<?php
$sql=”delete from liuyan where ly_id=$_GET[id]”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘删除成功!’);location.href=’../index.php’;</script>”);
?>

10、 如何进行会员登录验证
<?php
session_start();
$username=$_POST[“username”];
$password=$_POST[“password”];
$sql=”select * from admin where username='”.$username.”‘ && password='”.$password.”‘”;
$result=mysql_query($sql,$connec);
if($row=mysql_fetch_array($result)){
session_register(“admin”);
$admin=$username;
echo(“<script type=’text/javascript’> alert(‘登录成功!’);location.href=’admin.php’;</script>”);}
else
{
echo(“<script type=’text/javascript’> alert(‘你输入的用户名或密码错误,请重新输入!’);location.href=’login.php’;</script& gt;”);
}
mysql_close();
?>

11、如何对SESSION进行检验(后台检查页面的制作)
<?php
session_start();
if(!isset($_SESSION[“admin”])){
header(“location:login.php”);
exit;
}
?>

12、 验证用户名及密码是否填写(javascript)
<SCRIPT language=javascript>
<!–
function confirmlogin()
{
if (document.frmmain.username.value.length<4 || document.frmmain.username.value==””)
{
document.frmmain.username.focus();
document.frmmain.username.select;
window.alert(“请输入你的用户名!”);
return false;
}
if (document.frmmain.password.value.length<4)
{
document.frmmain.password.focus();
document.frmmain.password.select;
window.alert(“请输入你的密码!”);
return false;
}
return true;
}
//–>
</SCRIPT>

13、 在PHP中调用编辑器的方法
1)将编辑器文件夹放置后台管理文件夹内。
2)利用以下语句进行引入操作。
<input name=”content” type=”hidden” value=”>
<IFRAME ID=”eWebEditor1″ src=”eWebEditorPHP38/ewebeditor.htm?id=content&style=coolblue” frameborder=”0″ scrolling=”no” width=”550″ height=”350″></IFRAME>
注:eWebEditorPHP38编辑器文件夹的名称。
id=content中content为上面隐藏域的名称

14、循环输出(能够实现分列)
1)首先插入一行一列表格
<?php
$i=1;
?>
<table>
<tr>
<?php
while($rs=mysql_fetch_array($conn)){
?>
<td>
被循环的其它表格和输出
</td>
<?php
if ($i % 2==0) {
echo “</tr><tr>”;
}
$i++;
}
?>
</tr>
</table>

15、 给下拉列表框绑定数据(并且在修改时默认选中)
<select name=”fenleiid”>
<?php
$sql=”select * from fenleibiao”;
$conn=mysql_query($sql,$connec);
while($rs1=mysql_fetch_array($conn)){
?>
<option value=”<?=$rs1[“fenleiid”]?>”
<?
if ($rs[“fenleiid”]==$rs1[“fenleiid”]){
echo “selected” ;
}
?>>
<?=$rs1[“flname”]?>
</option>
<?php>
}
?>
</select>

16、获取字符长度函数
strlen($c)>12

17、 定义一个字符截取函数
用法:<?=substrgb($rs[“title”],10)?>
function substrgb($in,$num){
$pos=0;
$out=””;
while($c=substr($in,$pos,1)){
if($c==”n”) break;
if(ord($c)>128){
$out.=$c;
$pos++;
$c=substr($in,$pos,1);

$out.=$c;
}else{
$out.=$c;
}
$pos++;
if($pos>=$num) break;
}
if($out!=$in) $out = $out . “…”;
return $out;
}

18、判断是否是数字
!is_numeric(qq)

19、PHP技术中获取当前日期
$ptime=date(“y-m-d”);

20、用户注册时所使用的PHP验证程序
if ($admin==”” or (strlen($admin)>16) or (strlen($admin)<2)) {
echo “<SCRIPT language=JavaScript>alert(‘请输入用户名(不能大于16小于2)’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($password==”” or strlen($password)>16 or strlen($password)<6) {
echo “<SCRIPT language=JavaScript>alert(‘密码长度为6-16个字符’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($password==””) {
echo “<SCRIPT language=JavaScript>alert(‘确认密码不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}else{
if ($password!=$password1) {
echo “<SCRIPT language=JavaScript>alert(‘密码和确认密码不一致’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($wt=””) {
echo “<SCRIPT language=JavaScript>alert(‘密码问题不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($da=””) {
echo “<SCRIPT language=JavaScript>alert(‘问题答案不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;

}
if ($qq!=””) {
if (!is_numeric($qq)) {
echo “<SCRIPT language=JavaScript>alert(‘QQ号码必须是数字’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($youbian==”” or strlen($youbian)!=6) {
echo “<SCRIPT language=JavaScript>alert(‘请正确输入邮编’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($youbian!=””) {
if (!is_numeric($youbian)) {
echo “<SCRIPT language=JavaScript>alert(‘邮编必须是数字’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($dizhi=””) {
echo “<SCRIPT language=JavaScript>alert(‘住址不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($mail==””) {
echo “<SCRIPT language=JavaScript>alert(‘E-mail不能为空!’);”;
echo “this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($textarea==””) {
echo “<SCRIPT language=JavaScript>alert(‘个人说明不能为空!’);”;
echo “this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($textarea==”” or strlen(textarea)>150) {
echo “<SCRIPT language=JavaScript>alert(‘个人说明为150个字符’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}

24、对输出的内容进行判断,从而输出其它结果
<?php
if ($rs[“active”]==1) {
echo “<font color=’#ff0000′>激活</font>”;
}else{
echo “禁用”;
}
?>

25.字符截取函数
<?=substr(“$rs[zixun_biaoti]”,0,28)?>

26.男女问题或单选带选择的
<input type=”radio” name=”hy_zhuangtai” value=”男” <?php if ($rs[“hy_zhungtai”]===”男”) { echo “checked”;}?>>男
<input type=”radio” name=”hy_zhuangtai” value=”女” <?php if ($rs[“hy_zhuangtai”]===”女”) { echo “checked”;}?>>女

27.单选不带单选框的
<?php if ($rs[‘hy_zhuangtai’]==’锁定’){?>
<a href=”Userzt.php?action=yes&id=<?php echo $rs[‘hy_id’];?>”>锁定</a>
<?php }
else{?>
<a href=”Userzt.php?id=<?php echo $rs[‘hy_id’];?>&action=no”>解锁</a>
<?php }?>
它的 save页是
<?php require_once(‘http://www.cnblogs.com/conn.php’); ?>
<?php
$hy_id=$_GET[‘id’];
$action=$_GET[‘action’];
if ($action==’yes’){
$sql=”update hybiao set hy_zhuangtai=’锁定’ where hy_id=’$id'”;
$query=mysql_query($sql,$connec);
echo(“<script type=’text/javascript’>location.href=’UserManage.php’;</script>”);
}
else{
$sql=”update hybiao set hy_zhuangtai=’正常’ where hy_id=’$id'”;
$query=mysql_query($sql,$connec);
echo(“<script type=’text/javascript’>location.href=’UserManage.php’;</script>”);
}
mysql_close();
?>

28. 如果文字过长,则将过长的部分变成省略号显示
<DIV STYLE=”width: 120px; height: 50px; border: 0px solid blue;overflow: hidden; text-overflow:ellipsis”>
<NOBR> 就是比如有一行文字,很长,表格内一行显示不下.</NOBR>
</DIV>

29.
禁止复制,鼠标拖动选取
<body ondragstart=window.event.returnValue=false oncontextmenu=window.event.returnValue=false onselectstart=event.returnValue=false>
30.大 中 小 文字的变化
<script type=”text/javascript”>
function doZoom(size)
{document.getElementById(‘zoom’).style.fontSize=size+’px’;}
</script>
<span id=”zoom”>需要指定大小的文字</span>
<a href=”javascript:doZoom(16)”>大</a> <a href=”javascript:doZoom(14)”>中</a> <a href=”javascript:doZoom(12)”>小</a>

30.添加到收藏夹和设为首页
<a href=# onclick=”this.style.behavior=’url(#default#homepage)’; this.setHomePage(‘http://www.makewing.com/lanren/’);”>设为首页</a>
<a href=”javascript:window.external.AddFavorite(‘http://www.makewing.com /lanren/’,’懒人图库’)”>收藏本站</a>

31.记录并显示网页的最后修改时间
<script language=JavaScript>
document.write(“最后更新时间: ” + document.lastModified + “”)
</script>

32.节日倒计时
<Script Language=”JavaScript”>
var timedate= new Date(“October 1,2002”);
var times= “国庆节”;
var now = new Date();
var date = timedate.getTime() – now.getTime();
var time = Math.floor(date / (1000 * 60 * 60 * 24));
if (time >= 0)
document.write( “现在离”+times+”还有: “+time +”天”)
</Script>

33.打开窗口即最大化
<script language=”JavaScript”>
<!– Begin
self.moveTo(0,0)
self.resizeTo(screen.availWidth,screen.availHeight)
// End –>
</script>

34.加入背景音乐
<bgsound src=”mid/windblue[1].mid” loop=”-1″> 只适用于IE
<embed src=”music.mid” autostart=”true” loop=”true” hidden=”true”> 对Netscape ,IE 都适用

35.滚动
<marquee direction=up height=146 onmouseout=start() onmouseover=stop() scrollAmount=2>
滚动信息
</marquee>

36.防止点击空链接时,页面往往重置到页首端
代码“javascript:void(null)”代替原来的“#”标记

37.不能点右键,不用CTRL+A,不能复制作!
<body oncontextmenu=”window.event.returnValue=false”
onkeypress=”window.event.returnValue=false”
onkeydown=”window.event.returnValue=false”
onkeyup=”window.event.returnValue=false”
ondragstart=”window.event.returnValue=false”
onselectstart=”event.returnValue=false”>
</body>

37.随机变换背景图象(一个可以刷新心情的特效)
<Script Language=”JavaScript”>
image = new Array(4); //定义image为图片数量的数组
image [0] = ‘tu0.gif’ //背景图象的路径
image [1] = ‘tu1.gif’
image [2] = ‘tu2.gif’
image [3] = ‘tu3.gif’
image [4] = ‘tu4.gif’
number = Math.floor(Math.random() * image.length);
document.write(“<BODY BACKGROUND=”+image[number]+”>”);
</Script>

38.划过链接 手型鼠标
style=”cursor:hand”

39.如何关闭层
<div id=”Layer1″></div>
<a href=”#” onClick=”Layer1.style.display=’none'”>关闭层</a>

40.<a href=javascript:close()>[关闭窗口]</a>

41.凹陷文字背景为灰色
<div style=”width:300px;padding:20px;overflow:hidden;word-wrap:break-word;word-break:break:all; font-size:12px; line-height:18px; background-color:#eeeeee;”>
<font disabled>
怎么样,我凹下去了吧?<br>
你不想试试吗?<br>
<a href=”www.lenvo.cnhttp://www.lenvo.cn/”>www.lenvo.cn</a></font>
</div>

42.给表格做链接
<table width=”100%” onclick=”window.open(‘http://www.makewing.com/’, ‘_blank’)” style=”CURSOR:hand”>
<tr>
<td height=”100″ bgcolor=”f4f4f4″> </td>
</tr>
</table>

43.后退&关闭窗口
后退:javascript:history.back(1)
关闭:javascript:window.close();

44.如果文字过长,则将过长的部分变成省略号显示
<DIV STYLE=”width: 120px; height: 50px; border: 0px solid blue;overflow: hidden; text-overflow:ellipsis”>
<NOBR>就是比如有一行文字,很长,表格内一行显示不下.</NOBR>
</DIV>

45.禁止复制,鼠标拖动选取
<body ondragstart=window.event.returnValue=false oncontextmenu=window.event.returnValue=false onselectstart=event.returnValue=false>

1、连接MYSQL数据库代码
<?php
$connec=mysql_connect(“localhost”,”root”,”root”) or die(“不能连接数据库服务器: “.mysql_error());
mysql_select_db(“liuyanben”,$connec) or die (“不能选择数据库: “.mysql_error());
mysql_query(“set names ‘gbk'”);
?>

2、读取数据库,并实现循环输出
<?php
$sql=”select * from liuyan order by ly_id desc”;
$conn=mysql_query($sql,$connec);
while($rs=mysql_fetch_array($conn)){
?>
循环的内容………
<?php
}
?>

3、如何实现分页,包括两个函数,两个调用
1)两个函数
<?
//分页函数
function genpage(&$sql,$page_size=2)
{
global $prepage,$nextpage,$pages,$sums; //out param
$page = $_GET[“page”];
$eachpage = $page_size;
$pagesql = strstr($sql,” from “);
$pagesql = “select count(*) as ids “.$pagesql;
$conn = mysql_query($pagesql) or die(mysql_error());
if($rs = mysql_fetch_array($conn)) $sums = $rs[0];
$pages = ceil(($sums-0.5)/$eachpage)-1;
$pages = $pages>=0?$pages:0;
$prepage = ($page>0)?$page-1:0;
$nextpage = ($page<$pages)?$page+1:$pages;
$startpos = $page*$eachpage;
$sql .=” limit $startpos,$eachpage “;
}
// 显示分页
function showpage()
{
global $page,$pages,$prepage,$nextpage,$queryString; //param from genpage function
$shownum =10/2;
$startpage = ($page>=$shownum)?$page-$shownum:0;
$endpage = ($page+$shownum<=$pages)?$page+$shownum:$pages;

echo “共”.($pages+1).”页: “;
if($page>0)echo “<a href=$PHP_SELF?page=0$queryString>首页</a>”;
if($startpage>0)
echo ” … <b><a href=$PHP_SELF?page=”.($page-$shownum*2).”$queryString>?</a></b>”;
for($i=$startpage;$i<=$endpage;$i++)
{
if($i==$page) echo ” <b>[“.($i+1).”]</b> “;
else echo ” <a href=$PHP_SELF?page=$i$queryString>”.($i+1).”</a> “;
}
if($endpage<$pages)
echo “<b><a href=$PHP_SELF?page=”.($page+$shownum*2).”$queryString>?</a></b> … “;
if($page<$pages)
echo “<a href=$PHP_SELF?page=$pages$queryString>尾页</a>”;
}
//显示带分类的分页
function showpage1()
{
$fenlei=$_GET[“fenleiid”];
global $page,$pages,$prepage,$nextpage,$queryString; //param from genpage function
$shownum =10/2;
$startpage = ($page>=$shownum)?$page-$shownum:0;
$endpage = ($page+$shownum<=$pages)?$page+$shownum:$pages;

echo “共”.($pages+1).”页: “;
if($page>0)echo “<a href=$PHP_SELF?fenleiid=$fenlei&page=0$queryString>首页</a>”;
if($startpage>0)
echo ” … <b><a href=$PHP_SELF?fenleiid=$fenlei&page=”.($page-$shownum*2).”$queryString>?</a></b>”;
for($i=$startpage;$i<=$endpage;$i++)
{
if($i==$page) echo ” <b>[“.($i+1).”]</b> “;
else echo ” <a href=$PHP_SELF?fenleiid=$fenlei&page=$i$queryString>”.($i+1).”</a> “;
}
if($endpage<$pages)
echo “<b><a href=$PHP_SELF?fenleiid=$fenlei&page=”.($page+$shownum*2).”$queryString>?</a></b> … “;
if($page<$pages)
echo “<a href=$PHP_SELF?fenleiid=$fenlei&page=$pages$queryString>尾页</a& amp; gt;”;
}
?>
2)两个调用
第一个
<?php
$sql=”select * from liuyan order by ly_id desc”;
genpage($sql); //只需要正常代码加上这一行就ok。
$conn=mysql_query($sql,$connec);
while($rs=mysql_fetch_array($conn)){
?>
第二个
<?php
}
?>
<?php
showpage(); //显示页
?>
<?php
mysql_close();
?>

4、服务器端包含
<?php require_once(‘conn.php’); ?>

5、如何将一条记录写入数据库,然后提示并跳转页面
<?php
$ly_title=$_POST[“ly_title”];
$ly_content=$_POST[“ly_content”];
$ly_time=$_POST[“ly_time”];
$ly_author=$_POST[“ly_author”];
$ly_email=$_POST[“ly_email”];
$sql=”insert into liuyan(ly_title,ly_content,ly_time,ly_author,ly_email) values(‘”.$ly_title.”‘,'”.$ly_content.”‘,'”.$ly_time.”‘,'”.$ly_author.”‘,'”.$ly_email.”‘)”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘添加成功!’);location.href=’index.php’;</script>”);
?>

6、 弹出对话框,并发生页面跳转
<?php
echo(“<script type=’text/javascript’> alert(‘添加成功!’);location.href=’index.php’;</script>”);
?>

7、 信息查看页面(有条件读取数据库)
1)有条件读取数据库
<?php
$sql=”select * from liuyan where ly_id=$_GET[id]”;
$conn=mysql_query($sql,$connec);
$rs=mysql_fetch_array($conn);
?>
2) 将某个字段输出
<?=$rs[ly_title]?>
3)关闭数据库
<?php
mysql_close();
?>

8、对数据库中某一条记录进行更新操作,并作提示跳转
<?php
$ly_title=$_POST[“ly_title”];
$ly_content=$_POST[“ly_content”];
$ly_time=$_POST[“ly_time”];
$ly_author=$_POST[“ly_author”];
$ly_email=$_POST[“ly_email”];
$sql=”update liuyan set ly_title=’$ly_title’,ly_content=’$ly_content’,ly_time=’$ly_time’,ly_author=’$ly_author’,ly_email=’$ly_email’ where ly_id=$_GET[id]”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘更新成功!’);location.href=’../index.php’;</script>”);
?>

9、 如何删除数据库中的一条记录
<?php
$sql=”delete from liuyan where ly_id=$_GET[id]”;
mysql_query($sql,$connec);
echo(“<script type=’text/javascript’> alert(‘删除成功!’);location.href=’../index.php’;</script>”);
?>

10、 如何进行会员登录验证
<?php
session_start();
$username=$_POST[“username”];
$password=$_POST[“password”];
$sql=”select * from admin where username='”.$username.”‘ && password='”.$password.”‘”;
$result=mysql_query($sql,$connec);
if($row=mysql_fetch_array($result)){
session_register(“admin”);
$admin=$username;
echo(“<script type=’text/javascript’> alert(‘登录成功!’);location.href=’admin.php’;</script>”);}
else
{
echo(“<script type=’text/javascript’> alert(‘你输入的用户名或密码错误,请重新输入!’);location.href=’login.php’;</script& gt;”);
}
mysql_close();
?>

11、如何对SESSION进行检验(后台检查页面的制作)
<?php
session_start();
if(!isset($_SESSION[“admin”])){
header(“location:login.php”);
exit;
}
?>

12、 验证用户名及密码是否填写(javascript)
<SCRIPT language=javascript>
<!–
function confirmlogin()
{
if (document.frmmain.username.value.length<4 || document.frmmain.username.value==””)
{
document.frmmain.username.focus();
document.frmmain.username.select;
window.alert(“请输入你的用户名!”);
return false;
}
if (document.frmmain.password.value.length<4)
{
document.frmmain.password.focus();
document.frmmain.password.select;
window.alert(“请输入你的密码!”);
return false;
}
return true;
}
//–>
</SCRIPT>

13、 在PHP中调用编辑器的方法
1)将编辑器文件夹放置后台管理文件夹内。
2)利用以下语句进行引入操作。
<input name=”content” type=”hidden” value=”>
<IFRAME ID=”eWebEditor1″ src=”eWebEditorPHP38/ewebeditor.htm?id=content&style=coolblue” frameborder=”0″ scrolling=”no” width=”550″ height=”350″></IFRAME>
注:eWebEditorPHP38编辑器文件夹的名称。
id=content中content为上面隐藏域的名称

14、循环输出(能够实现分列)
1)首先插入一行一列表格
<?php
$i=1;
?>
<table>
<tr>
<?php
while($rs=mysql_fetch_array($conn)){
?>
<td>
被循环的其它表格和输出
</td>
<?php
if ($i % 2==0) {
echo “</tr><tr>”;
}
$i++;
}
?>
</tr>
</table>

15、 给下拉列表框绑定数据(并且在修改时默认选中)
<select name=”fenleiid”>
<?php
$sql=”select * from fenleibiao”;
$conn=mysql_query($sql,$connec);
while($rs1=mysql_fetch_array($conn)){
?>
<option value=”<?=$rs1[“fenleiid”]?>”
<?
if ($rs[“fenleiid”]==$rs1[“fenleiid”]){
echo “selected” ;
}
?>>
<?=$rs1[“flname”]?>
</option>
<?php>
}
?>
</select>

16、获取字符长度函数
strlen($c)>12

17、 定义一个字符截取函数
用法:<?=substrgb($rs[“title”],10)?>
function substrgb($in,$num){
$pos=0;
$out=””;
while($c=substr($in,$pos,1)){
if($c==”n”) break;
if(ord($c)>128){
$out.=$c;
$pos++;
$c=substr($in,$pos,1);

$out.=$c;
}else{
$out.=$c;
}
$pos++;
if($pos>=$num) break;
}
if($out!=$in) $out = $out . “…”;
return $out;
}

18、判断是否是数字
!is_numeric(qq)

19、PHP技术中获取当前日期
$ptime=date(“y-m-d”);

20、用户注册时所使用的PHP验证程序
if ($admin==”” or (strlen($admin)>16) or (strlen($admin)<2)) {
echo “<SCRIPT language=JavaScript>alert(‘请输入用户名(不能大于16小于2)’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($password==”” or strlen($password)>16 or strlen($password)<6) {
echo “<SCRIPT language=JavaScript>alert(‘密码长度为6-16个字符’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($password==””) {
echo “<SCRIPT language=JavaScript>alert(‘确认密码不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}else{
if ($password!=$password1) {
echo “<SCRIPT language=JavaScript>alert(‘密码和确认密码不一致’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($wt=””) {
echo “<SCRIPT language=JavaScript>alert(‘密码问题不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($da=””) {
echo “<SCRIPT language=JavaScript>alert(‘问题答案不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;

}
if ($qq!=””) {
if (!is_numeric($qq)) {
echo “<SCRIPT language=JavaScript>alert(‘QQ号码必须是数字’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($youbian==”” or strlen($youbian)!=6) {
echo “<SCRIPT language=JavaScript>alert(‘请正确输入邮编’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($youbian!=””) {
if (!is_numeric($youbian)) {
echo “<SCRIPT language=JavaScript>alert(‘邮编必须是数字’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
}
if ($dizhi=””) {
echo “<SCRIPT language=JavaScript>alert(‘住址不能为空’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($mail==””) {
echo “<SCRIPT language=JavaScript>alert(‘E-mail不能为空!’);”;
echo “this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($textarea==””) {
echo “<SCRIPT language=JavaScript>alert(‘个人说明不能为空!’);”;
echo “this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}
if ($textarea==”” or strlen(textarea)>150) {
echo “<SCRIPT language=JavaScript>alert(‘个人说明为150个字符’);”;
echo”this.location.href=’vbscript:history.back()’;</SCRIPT>”;
}

24、对输出的内容进行判断,从而输出其它结果
<?php
if ($rs[“active”]==1) {
echo “<font color=’#ff0000′>激活</font>”;
}else{
echo “禁用”;
}
?>

25.字符截取函数
<?=substr(“$rs[zixun_biaoti]”,0,28)?>

26.男女问题或单选带选择的
<input type=”radio” name=”hy_zhuangtai” value=”男” <?php if ($rs[“hy_zhungtai”]===”男”) { echo “checked”;}?>>男
<input type=”radio” name=”hy_zhuangtai” value=”女” <?php if ($rs[“hy_zhuangtai”]===”女”) { echo “checked”;}?>>女

27.单选不带单选框的
<?php if ($rs[‘hy_zhuangtai’]==’锁定’){?>
<a href=”Userzt.php?action=yes&id=<?php echo $rs[‘hy_id’];?>”>锁定</a>
<?php }
else{?>
<a href=”Userzt.php?id=<?php echo $rs[‘hy_id’];?>&action=no”>解锁</a>
<?php }?>
它的 save页是
<?php require_once(‘http://www.cnblogs.com/conn.php’); ?>
<?php
$hy_id=$_GET[‘id’];
$action=$_GET[‘action’];
if ($action==’yes’){
$sql=”update hybiao set hy_zhuangtai=’锁定’ where hy_id=’$id'”;
$query=mysql_query($sql,$connec);
echo(“<script type=’text/javascript’>location.href=’UserManage.php’;</script>”);
}
else{
$sql=”update hybiao set hy_zhuangtai=’正常’ where hy_id=’$id'”;
$query=mysql_query($sql,$connec);
echo(“<script type=’text/javascript’>location.href=’UserManage.php’;</script>”);
}
mysql_close();
?>

28. 如果文字过长,则将过长的部分变成省略号显示
<DIV STYLE=”width: 120px; height: 50px; border: 0px solid blue;overflow: hidden; text-overflow:ellipsis”>
<NOBR> 就是比如有一行文字,很长,表格内一行显示不下.</NOBR>
</DIV>

29.
禁止复制,鼠标拖动选取
<body ondragstart=window.event.returnValue=false oncontextmenu=window.event.returnValue=false onselectstart=event.returnValue=false>
30.大 中 小 文字的变化
<script type=”text/javascript”>
function doZoom(size)
{document.getElementById(‘zoom’).style.fontSize=size+’px’;}
</script>
<span id=”zoom”>需要指定大小的文字</span>
<a href=”javascript:doZoom(16)”>大</a> <a href=”javascript:doZoom(14)”>中</a> <a href=”javascript:doZoom(12)”>小</a>

30.添加到收藏夹和设为首页
<a href=# onclick=”this.style.behavior=’url(#default#homepage)’; this.setHomePage(‘http://www.makewing.com/lanren/’);”>设为首页</a>
<a href=”javascript:window.external.AddFavorite(‘http://www.makewing.com /lanren/’,’懒人图库’)”>收藏本站</a>

31.记录并显示网页的最后修改时间
<script language=JavaScript>
document.write(“最后更新时间: ” + document.lastModified + “”)
</script>

32.节日倒计时
<Script Language=”JavaScript”>
var timedate= new Date(“October 1,2002”);
var times= “国庆节”;
var now = new Date();
var date = timedate.getTime() – now.getTime();
var time = Math.floor(date / (1000 * 60 * 60 * 24));
if (time >= 0)
document.write( “现在离”+times+”还有: “+time +”天”)
</Script>

33.打开窗口即最大化
<script language=”JavaScript”>
<!– Begin
self.moveTo(0,0)
self.resizeTo(screen.availWidth,screen.availHeight)
// End –>
</script>

34.加入背景音乐
<bgsound src=”mid/windblue[1].mid” loop=”-1″> 只适用于IE
<embed src=”music.mid” autostart=”true” loop=”true” hidden=”true”> 对Netscape ,IE 都适用

35.滚动
<marquee direction=up height=146 onmouseout=start() onmouseover=stop() scrollAmount=2>
滚动信息
</marquee>

36.防止点击空链接时,页面往往重置到页首端
代码“javascript:void(null)”代替原来的“#”标记

37.不能点右键,不用CTRL+A,不能复制作!
<body oncontextmenu=”window.event.returnValue=false”
onkeypress=”window.event.returnValue=false”
onkeydown=”window.event.returnValue=false”
onkeyup=”window.event.returnValue=false”
ondragstart=”window.event.returnValue=false”
onselectstart=”event.returnValue=false”>
</body>

37.随机变换背景图象(一个可以刷新心情的特效)
<Script Language=”JavaScript”>
image = new Array(4); //定义image为图片数量的数组
image [0] = ‘tu0.gif’ //背景图象的路径
image [1] = ‘tu1.gif’
image [2] = ‘tu2.gif’
image [3] = ‘tu3.gif’
image [4] = ‘tu4.gif’
number = Math.floor(Math.random() * image.length);
document.write(“<BODY BACKGROUND=”+image[number]+”>”);
</Script>

38.划过链接 手型鼠标
style=”cursor:hand”

39.如何关闭层
<div id=”Layer1″></div>
<a href=”#” onClick=”Layer1.style.display=’none'”>关闭层</a>

40.<a href=javascript:close()>[关闭窗口]</a>

41.凹陷文字背景为灰色
<div style=”width:300px;padding:20px;overflow:hidden;word-wrap:break-word;word-break:break:all; font-size:12px; line-height:18px; background-color:#eeeeee;”>
<font disabled>
怎么样,我凹下去了吧?<br>
你不想试试吗?<br>
<a href=”www.lenvo.cnhttp://www.lenvo.cn/”>www.lenvo.cn</a></font>
</div>

42.给表格做链接
<table width=”100%” onclick=”window.open(‘http://www.makewing.com/’, ‘_blank’)” style=”CURSOR:hand”>
<tr>
<td height=”100″ bgcolor=”f4f4f4″> </td>
</tr>
</table>

43.后退&关闭窗口
后退:javascript:history.back(1)
关闭:javascript:window.close();

44.如果文字过长,则将过长的部分变成省略号显示
<DIV STYLE=”width: 120px; height: 50px; border: 0px solid blue;overflow: hidden; text-overflow:ellipsis”>
<NOBR>就是比如有一行文字,很长,表格内一行显示不下.</NOBR>
</DIV>

45.禁止复制,鼠标拖动选取
<body ondragstart=window.event.returnValue=false oncontextmenu=window.event.returnValue=false onselectstart=event.returnValue=false>

老爸日記

愚笨女人與聰明女人

愚笨的女人盯着男人的缺點,老是生氣;
聰明的女人欣賞男人的優點,很是開心。

愚笨的女人不分場合與男人爭吵,弄得男人很沒面子;
聰明的女人在外人面前給足男人面子,私下再對男人嚴加管教。

愚笨的女人貶低男人——她忘了:貶低男人就是貶低自己;
聰明的女人贊賞男人——她明白:贊賞男人才是炫耀自己。

愚笨的女人不停地嘮叨那些陳年舊事;
聰明的女人與男人一起憧憬美好未來。

愚笨的女人抓住男人的過錯不放,以為自己看透了男人的本質;
聰明的女人原諒男人,把男人比作永遠長不大的孩子。

愚笨的女人會說“你給我滾!”;
聰明的女人會說“不許離開我!”

愚笨的女人把男人當彈弓,拉得越緊,飛得越遠;
聰明的女人把男人當風箏,悠然地牽着手中的線。

愚笨的女人過于強調自我;
聰明的女人善于寄托和依靠。

愚笨的女人對男人寸步不離;
聰明的女人和男人若即若離。

愚笨的女人知道洗衣做飯,但不願再梳妝打扮;
聰明的女人也知道洗衣做飯,但不忘扮靚自己。

愚笨的女人帶給男人壓抑和壓力;
聰明的女人帶給男人激情和動力。

愚笨的女人使男人在她的淚水中失敗;
聰明的女人使男人在她的笑容中成功。

愚笨的女人打擊男人;
聰明的女人激勵男人。
身邊生活中,你會發現:

不乏自以為是愛耍小聰明的愚笨女人,
亦有幸遇上大智若愚處事恰當的聰明女人。

女人,
你願意做積極樂觀、幸福開心的聰明女人,
抑或甘為終日抱怨、自毀家園的愚笨女人?

老爸日記

出軌女人與佛的對話

深夜,寺里一人一佛,佛坐人站。
人:聖明的佛,我是一個已婚之人,我現在狂熱地愛上了另一個男人,我一天不見他都很難受!我真的不知道該怎幺辦。
佛:你能確定你現在愛上的這個男人就是你生命里唯一的最后一個男人嗎?
人:是的。 我有很多年沒有動心了!遇上的這一刻,我不想錯過!
佛:你離婚,然后嫁他。
人:可是我現在的愛人勤奮,善良,有責任,我這樣做是否有一點殘忍,有一點不道德。
佛:在婚姻中沒有愛才是殘忍和不道德的,你現在愛上了別人已不愛他了,你這樣做是正確的。
人:可是我愛人很愛我,真的很愛我。
佛:那他就是幸福的。
人:我要與他離婚后另嫁他人,他應該是很痛苦的又怎幺會是幸福的呢?
佛:在婚姻里他還擁有他對你的愛,而你在婚姻中已失去對他的愛, 因為你愛上了別人,正謂擁有的就是幸福的,失去的才是痛苦的,所以痛苦的人是你。
人:可是我要和他離婚后另嫁他人,應該是他失去了我,他應該才是痛苦的。
佛:你錯了,你只是他婚姻中真愛的一個具體,當你這個具體不存在的時候,他的真愛會延續到另一個具體,因為他在婚姻中的真愛從沒有失去過。所以他才是幸福的而你才是痛苦的。
人:他說過今生只愛我一個,他不會愛上別人的。
佛:這樣的話你也說過嗎?
人:我。我。。我。。。
佛:你現在看你面前香爐里的三根蠟燭,那根最亮。
人:我真的不知道,好象都是一樣的亮。
佛:這三根蠟燭就好比是三個男人,其中一根就是你現在所愛的那個男人,芸芸眾生,男人何止千百萬萬,你連這三根蠟燭那根最亮都不知道,都不能把你現在愛的人找出來,你為什么又能確定你現在愛的這個男人就是你生命里唯一的最后一個男人呢?
人:我。我。。我。。。
佛:你現在拿一根蠟燭放在你的眼前,用心看看那根最亮
人:當然是眼前的這根最亮。
佛:你現在把它放回原處,再看看那根最亮
人:我真的還是看不出那根最亮。
佛:其實你剛拿的那根蠟燭就是好比是你現在愛的那個最后的男人,所謂愛由心生,當你感覺你愛她時,你用心去看就覺的它最亮,當你把它放回原處,你卻找不到最亮的一點感覺,你這種所謂的最后的唯一的愛只是鏡花水月,到頭來終究是一場空。
人:哦,我懂了,你并不是要我與我的愛人離婚,你是在點化我,
佛:看破不說破,你去吧
人:我現在真的知道我愛的是誰了,他就是我現在的愛人。
佛:阿彌陀佛,阿彌陀佛
你我曾經深愛過的某人,無非也就是芸芸眾生中的一個,只是愛由心生,自以為他/她會是今生最愛,當你感覺你愛他,你用心去愛就覺的他/她最珍貴,當萬物歸原,生命仍然繼續,他/她無非也就是我們生命中的一個過客。
我們根本無法確定哪一個才是今生最愛,如果不懂得去珍惜,你身邊這個愛你的/你愛的人,在某一天,也會成為你身邊的過客。
找一個你愛的人不容易,找一個愛你的人也不容易。如果無法確定哪一個才是你最愛的人,何不在自己成為別人的愛人的時候珍惜這份感情?愛由心生,你告訴自己是愛他/她的,自然就可以愛上他/她。
如果你愛的人不愛你,也請記得:愛由心生。是你太過于把目光集中在他/她身上了,試着放開視線焦點,你會發現光亮的蠟燭到處都有。
愛與不愛,無非也就是在一念之間。
過去的事情過去的愛情,就讓它過去吧,那只是我們生命的一部分,只是茫茫大海中的一滴水珠,只是漫漫蒼弩中的一粒微塵。沒有那些過去,也不會造就現在的你我。
珍惜當前,永遠勝于三心二意。

老爸日記

~~狠心父母 將子活埋~~

這不是新聞!呵,衹是借用傳媒常用的那種“語不驚人心不死”的慣用手法開一下標題黨玩笑而已。

周日一家大小忽然興致去了淺水灣,囝囝最興奮也最快樂。皆因老爸教子一向宗旨是放任自由、開心無價(有什麼比自由、快樂更重要?)--衹要沒生命危險之虞憂就盡量放膽去試,不會造成不可挽回的錯犯也無妨。所以經常受旁人非議,家中長輩如是,尤其與孩子他媽觀念理念一向相左, 一同外游的話自然多些磨擦產生不愉快之事,難得此行能她一改性情,並無阻撓多加干涉,且還能一同玩樂投入放縱。
此次乃最自由、無拘無束的一天,但願將來的日子亦能如此,則為快哉!

 

返回頂端