道不远人,深入.net底层技术
业精于勤荒于嬉,行成于思毁于随!
posts - 51,  comments - 18,  trackbacks - 0
摘要: 人生而自由,却无往不在枷锁中。你最大的敌人是你对面的那个人吗?不,你最大的敌人确切的说是你自己,是你自己的心魔。刘备最大的心魔是刘备,曹操最大的心魔是曹操,吕布最大的心魔是吕布。所谓英雄,不过是最大限度地打破自己的局限甚至走到局限的对立面的那个人。 ---最三国阅读全文
posted @ 2010-05-08 12:23 扬帆起航 阅读(57) 评论(0) 编辑
摘要: .net 开发人员当前必须掌握的技术阅读全文
posted @ 2008-10-31 00:09 扬帆起航 阅读(536) 评论(1) 编辑
摘要: 不习惯的时候就是成长的时候阅读全文
posted @ 2008-10-11 22:14 扬帆起航 阅读(145) 评论(6) 编辑

JSON(JavaScript Object Notation)javscript对象标记,是一种轻量级的数据交换格式。具体的详细基础知识可以参考JSON官网http:/www.json.org/

不说太多废话,直接说说我对JSON的理解吧。

一、JSON的一些基础知识。

JSON中对象通过“{}”来标识,一个“{}”代表一个对象,如{“AreaId”:”123”},对象的值是键值对的形式(keyvalue)。

 

[]”,标识数组,数组内部各个数据之间通过“,”分割,如[“AreaId”:”123””AreaId”:”345”]

很多情况下是对象数组,那就是这样:

[{“AreaId”:”123”},{“AreaId”:”345”}]

 

其实数组也是一个对象,上面的格式也可以写成这样:

{Area”:[{“AreaId”:”123”},{“AreaId”:”345”}]}

这表示一个Area对象,他有两个子数据,每个子数据也是一个对象,每个子对象都是AreaId

 

JSON中字符串和字符的定义格式和一般的类C语言定义是类似的,双引号定义字符串,单引号定义字符。

JSON的键(Key)用双引号括起来,比如上面的“Area“和”AreaId“,都是用双引号括起来的,在一些语言中构造JSON字符串的时候,可以使用转义字符转义双引号。

 

二、javascript操作JSON字符

1、先要区分JSON字符串和JSON对象

JSON字符串:

Var strJSON = “{\“Area\”[{\“AreaId\”:\”123\”},{\“AreaId\”:\”345\”}]}”

其实也可以写成这样:

Var strJSON = ‘{“Area”[{“AreaId”:”123”},{“AreaId”:”345”}]}’

这表示一个JSON字符串,由于在Js中单引号和双引号都可以表示一个字符串,所以上面第一个使用双引号和第二个使用单引号的都表示一个JSON字符串。

下面看看JSON对象

Var JSON = {“Area”[{“AreaId”:”123”},{“AreaId”:”345”}]},

看到了吧,JSON对象最外面是没有单引号或者双引号的,这就表示一个JSON对象。

 

2JSON字符串向JSON对象转换

直接只用JSeval()方法。

如上面的strJSON字符串可以这样转换为JSON对象

Var JSON = eval”(”+strJSON+”)”),

这样就转换为JSON对象了。

 

据说使用jseval()方法有安全上的问题,所以好多人推荐使用JSON官网的json.js包进行转换,但是我去JSON官网下载这个包的时候,发现只有一句话那就是alert(’error’)。不知什么原因,哪位有知道的希望告知一下。

 

由于使用的JQuery,而且听说Jquery和json.js有冲突,于是参考JQuery json.js 冲突问题这篇文章下载了处理jsonjquery插件。

那个插件挺好用的,比如以上的把json字符串转换为JSON对象:

Var JSON = $.parseJSON(strJSON);

这样就可以使用JSON对象了。

其实在Jquery1.4.1之后JQuery也已经添加了对JSON处理的方法,方法名也是parseJSON(str),具体使用也是和上面一样,如果你使用的是1.4.1之后的版本那就不用上面的那个插件了,直接用那个方法就可以了。

如果要是使用Jquery的ajax方法,也可以直接使用getJSON方法,就可以直接获得JSON对象,无需转换。

3、处理JSON数据

获得JSON对象后,就应该处理JSON对象了,比如通过前面的那个strJSON字符串获得JSON对象之后,可以这样获得JSON对象的值

Var firstAreaId = JSON.Area[0].AreaId.

JSON是刚才生成的JSON对象,Area[0]表示JSON对象的第一个Area对象(因为Area对象有两个子对象),AreaId就是要获得子对象的数据。

posted @ 2011-07-26 17:24 扬帆起航 阅读(182) 评论(0) 编辑

SQLite批量插入优化方法

SQLite的数据库本质上来讲就是一个磁盘上的文件,所以一切的数据库操作其实都会转化为对文件的操作,而频繁的文件操作将会是一个很好时的过程,会极大地影响数据库存取的速度。
例如:向数据库中插入100万条数据,在默认的情况下如果仅仅是执行
sqlite3_exec(db, “insert into name values ‘lxkxf', ‘24'; ”, 0, 0, &zErrMsg);
将会重复的打开关闭数据库文件100万次,所以速度当然会很慢。因此对于这种情况我们应该使用“事务”。
具体方法如下:在执行SQL语句之前和SQL语句执行完毕之后加上
rc = sqlite3_exec(db, "BEGIN;", 0, 0, &zErrMsg);
//执行SQL语句
rc = sqlite3_exec(db, "COMMIT;", 0, 0, &zErrMsg);
这样SQLite将把全部要执行的SQL语句先缓存在内存当中,然后等到COMMIT的时候一次性的写入数据库,这样数据库文件只被打开关闭了一次,效率自然大大的提高。有一组数据对比:
测试1: 1000 INSERTs
CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100));
INSERT INTO t1 VALUES(1,13153,'thirteen thousand one hundred fifty three');
INSERT INTO t1 VALUES(2,75560,'seventy five thousand five hundred sixty');
... 995 lines omitted
INSERT INTO t1 VALUES(998,66289,'sixty six thousand two hundred eighty nine');
INSERT INTO t1 VALUES(999,24322,'twenty four thousand three hundred twenty two');
INSERT INTO t1 VALUES(1000,94142,'ninety four thousand one hundred forty two');
SQLite 2.7.6:
13.061
SQLite 2.7.6 (nosync):
0.223

测试2: 使用事务 25000 INSERTs
BEGIN;

CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100));

INSERT INTO t2 VALUES(1,59672,'fifty nine thousand six hundred seventy two');
...
INSERT INTO t2 VALUES(24999,89569,'eighty nine thousand five hundred sixty nine');
INSERT INTO t2 VALUES(25000,94666,'ninety four thousand six hundred sixty six');

COMMIT;

可见使用了事务之后却是极大的提高了数据库的效率。但是我们也要注意,使用事务也是有一定的开销的,所以对于数据量很小的操作可以不必使用,以免造成而外的消耗。


 

posted @ 2011-05-31 10:13 扬帆起航 阅读(678) 评论(0) 编辑

1. Regex使用的一点理解 http://www.cnblogs.com/panjun-Donet/archive/2008/07/19/1246787.html

2. RegeX使用教程 http://www.cnblogs.com/SkyD/archive/2008/09/22/1295620.html

 

posted @ 2011-05-25 17:07 扬帆起航 阅读(16) 评论(0) 编辑
select * From V_XT_XTGNDY start with GNDYXH
IN
(
select GNDYXH From V_XT_XTGNDY WHERE XTMKXH='201'
  AND GNDYXH IN (SELECT GNDYXH FROM XT_YHFZQX WHERE YHFZBH IN (SELECT YHFZBH FROM XT_YHFZCY WHERE YHRYDM='DBA'))
)
connect by prior FLDYXH=GNDYXH
posted @ 2011-04-27 19:38 扬帆起航 阅读(18) 评论(0) 编辑

表: ZZJCBGD

字段:TianKaSJ 日期型

         JiuZhenSJ varchar型

 

获取年份:

select to_char(TianKaSJ,'YYYY') From ZZjcbgd;

select to_char(to_date(JiuZhenSJ,'YYYY-MM-DD hh24:mi:ss'),'YYYY') From zzjcbgd;

 

posted @ 2010-12-29 15:15 扬帆起航 阅读(149) 评论(0) 编辑
摘要: 发现遇到的人还比较多,所以在网上搜了一下,再稍作整理。VS2008按F5无法在断点处停留,主要有以下几种情况:1、生成方式是Realse不是Debug。2、调试时到“附加到进程”菜单里看有没有“aspnet_wp.exe”的进程,如果没有,添加。3、控件的事件丢失。这个比较常见。4、右键解决方案的属性里,看生成项里的“生成调试信息”那里是不是FALSE,如果是,改成TRUE。5、想要调试的代码行根本不能调试。这个比较少见。6、在vs2008中,工具->选项->调试->常规中有个选项,要求源文件与原始版本完全一致,vs2008默认的是选中的,取消试试。7、还有一种修改注册表的方法方法 1: 禁用阅读全文
posted @ 2010-12-23 18:26 扬帆起航 阅读(439) 评论(0) 编辑
摘要: 安装: 关于Windows 7下IIS7.5的伪静态的介绍好像很少,一般都是Vista下的IIS7.0,不过好在IIS7.0和IIS7.5差别并不是很大,不过对于我这个直接从IIS5.1跳到IIS7.5的人来说还是有点小麻烦的,从5.1到7.5变化还是蛮大的。 实现asp.net网站整站伪静态化需要以下条件: 1.IIS7.0 (目前Url Rewrite Module仅支持IIS7); 2.Url Rewrite Module,下载地址:http://www.iis.net/expand/URLRewrite 下面说下IIS7.5下伪静态(Rewrite)的安装,安装很傻瓜式的,下载这个组件,下载好了直接安装下酒可以了。 安装好了之后我们打开IIS,即可在网站IIS的配置中看到 URL rewrite的选项 阅读全文
posted @ 2010-09-26 09:21 扬帆起航 阅读(897) 评论(1) 编辑
摘要: EasyBCD阅读全文
posted @ 2010-08-31 09:06 扬帆起航 阅读(113) 评论(0) 编辑
摘要: 第一:做行业网站,用专业的服务来盈利 第二:做最新、唯一的内容,靠会员来盈利 第三:做品牌的平台 第四:就是做流量站靠广告盈利 第一:淘宝客 第二:Google广告 阅读全文
posted @ 2010-08-28 10:04 扬帆起航 阅读(294) 评论(0) 编辑
摘要: 05年看过一本书叫“管道”,最近又在看一本类似于此类书籍“赚钱机器”,感觉自己最近又身体比较累,长期这样打工下去也不是长久之计, 现在自己的情况是去工作就有钱,不工作就断“粮”,那么如何才能让自己睡觉时休息时也能够有钱赚,最近一直冥思苦想,都不知道如何打造我的一台“赚钱机器”, 长期以来本来一直专注于行业软件的开发,对互联网接触不是太深,所以这里将转载一些网站赢利模式的文章,希望给自己一个启发。 阅读全文
posted @ 2010-08-28 10:02 扬帆起航 阅读(28) 评论(0) 编辑
仅列出标题  下一页