随笔2

24、SQLite中Oracle函数的替代方法

1) nvl => ifnull

nvl直接替换为ifnull即可
注意:仅检查值为null的情况,假如为空字符串('')则不会触发,在这种情况下不能直接替换

2) decode => case when then

Oracle

SELECT ID, DECODE(inParam, 'byComparedParam', '值1' , '值2') name FROM test_table;

--如果第一个参数 inParam == 'byComparedParam',则 select 得到的 name 显示为值1
--如果第一个参数 inParam != 'byComparedParam',则 select 得到的 name 显示为值2

SQLite

select report_code, year, month, day, wind_speed,
case
    when wind_speed >= 40 then 'HIGH'
    when wind_speed >= 30 and wind_speed < 40 then 'MODERATE'
    else 'LOW'
end as wind_severity
from station_data

3) to_char => strftime

Oracle

select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual

SQLite

select strftime('%Y-%m-%d %H:%M:%S', 'now') from t_b_database_basic t
--select strftime('%Y-%m-%d %H:%M:%S', 'now', 'localtime') from t_b_database_basic t
select strftime('%Y-%m-%d %H:%M:%S', t.fcreate_time) from t_b_database_basic t

需要注意的是,假如转换为字符串的是代表当前时间的'now',结果将会是utc时间,显示为当地时间需添加修饰符'localtime',假如转换的是字段就不用担心这个问题,原因可能是因为内部处理的所有时间都默认为utc时间

4) to_date => datetime

Oracle

insert into t_timestamp_temp (create_time) values (to_date('2008-08-08 08:08:08' , 'yyyy-mm-dd hh24:mi:ss'));

SQLite

insert into t_timestamp_temp (create_time) values (datetime('2008-08-08 08:08:08'));
--insert into t_timestamp_temp (create_time) values (datetime('now', 'localtime'));

需要注意的是,转换为日期时默认处理的是utc时间,因此使用本地时间的固定字符串时不要添加修饰符'localtime',否则时间会根据时区改变,只有在使用'now'时才需要添加'localtime'修饰符

5) listagg => group_concat

Oracle

--param_code排序并拼接为字符串
select listagg(d.fparam_code, ',') within group(order by d.fparam_code)
  from t_b_meter_detail d where d.fmeter_no = 1

SQLite

--param_code拼接为字符串,可分组,不可排序
select group_concat(d.fparam_code, ',')
  from t_b_meter_detail d
  group by d.fmeter_no

6) merge into => insert into (...) select ... from ...(merge into替代方法的其中一种)

Oracle

      merge into t_b_meter t using t_b_esubstation m
      on (upper(t.fparent_meter_no) = 'ROOT' and t.fmeter_no = m.fstation_code)
      when not matched then
      insert (fid, fparent_meter_no, fmeter_no, fmeter_mark, fguihao, fmeter_type_code, fmodule_code)
        values (seq_b_meter.nextval, 'ROOT', m.fstation_code, m.fstation_name, m.fstation_name, '0', '0')

SQLite
(when not matched部分)与Oracle的语法相比,需要将表名提到insert语句中,insert语句的字段部分保持不变,values部分直接替换为select,而select从句部分需要有where条件限制以验证using表的字段在merge into表中不存在

      insert into t_b_meter (fparent_meter_no, fmeter_no, fmeter_mark, fguihao, fmeter_type_code, fmodule_code)
      select 'ROOT', m.fstation_code, m.fstation_name, m.fstation_name, '0', '0' from t_b_esubstation m
        where m.fstation_code not in (select t.fmeter_no from t_b_meter t where upper(t.fparent_meter_no) = 'ROOT')

7) merge into => insert into (...) ; update ... (merge into 替代方法的另外一种)

Oracle

    merge into #{TableName} t using (select #{CabinetCode} fguihao from dual) s on (s.fguihao = t.fguihao)
      when matched then
        update set fmeter_no = #{MeterNo}, fcomm_error = #{CommError}
      when not matched then
        insert (fmeter_no, fguihao, fcomm_error) values (#{MeterNo}, #{CabinetCode}, #{CommError})

SQLite
merge into中存在when not matchedwhen matched两部分,需拆分为insertupdate语句两部分,其中insert对应when not matched部分,在上文小节6)中提到
(when matched部分)与Oracle的语法相比,需要将表名提到update语句中,update语句的字段部分保持不变,然后在已有基础上需要添加where从句限制以验证merge into表数据符合using表的条件

    insert into #{TableName} (fmeter_no, fguihao, fcomm_error)
    select #{MeterNo}, #{CabinetCode}, #{CommError} from dual
      where #{CabinetCode} not in (select t.fguihao from #{TableName} t);
    update #{TableName} set fmeter_no = #{MeterNo}, fcomm_error = #{CommError}
      where fguihao = #{CabinetCode,jdbcType=VARCHAR}

8) 查询所有表 user_tables => sqlite_master

Oracle

select table_name from user_tables
  order by table_name

SQLite

SELECT name table_name FROM sqlite_master
  WHERE type='table' --类型有table, trigger等
  ORDER BY name;

9) 查询表字段 user_tab_columns => pragma table_info(...)

Oracle

    select u.column_name, u.data_type, u.table_name from user_tab_columns u
      where u.table_name = '#{TableName}'
      order by u.column_name

SQLite

    pragma table_info('#{TableName}')
pragma table_info 结果

name对应column_name,type对应data_type

n) =>

Oracle


SQLite


25、SQLite小知识

1) 限制返回结果条数

select * from t_b_meter limit 20

26、Windows开机自动登录

1) 步骤

打开运行,运行命令:netplwiz


命令

取消下图中勾选框,点击应用并输入用户名密码,然后确定即可


界面

输入用户名密码

2) 假如没有勾选框

没有勾选框

运行命令regedit,打开注册表,在地址栏输入
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device
然后回车,将DevicePasswordLessBuildVersion项的值改成0然后确定


修改值为0

修改完成后再重新进行步骤1)即可

27、BOOTP/DHCP配置工具一般配置步骤

1) 打开软件后,有些工具会自动搜索MAC地址,假如不支持就手动点击界面的搜索功能按钮

Ethernet IP Configuration

BootP DHCP Commissioning Tool

IP Setting Tool

2) 设置IP

2.1) Ethernet IP Configuration 工具

选中要设置的设备,点enable dhcp,再输入要设置的ip,然后点set ip configuration


Ethernet IP Configuration 操作步骤

2.2) BootP DHCP Commissioning Tool

点击“Add Relation”(或“Add to Relation List”),输入IP地址,点击“OK”


BootP DHCP Commissioning Tool 操作步骤

2.3) IP Setting Tool

选中设备,点击“IP地址设定”,在弹出窗口内输入IP地址,并点击“OK”


IP Setting Tool 操作步骤

3) 最好点disable bootp/dhcp,或者其它关闭BOOTP/DHCP功能的方法,以使设置的ip地址成为静态的

Ethernet IP Configuration 关闭DHCP

BootP DHCP Commissioning Tool 关闭DHCP

28、反正切函数相加减的公式

arctan A + arctan B=arctan[(A+B) / (1-AB)]
arctan A - arctan B=arctan[(A-B) / (1+AB)]

29、程序延时开机启动

要实现程序的延时启动,可以通过创建一个批处理文件来实现。以下是在Windows系统中实现程序延时启动的步骤:

1) 打开文本编辑器(例如记事本)

在文本编辑器中输入以下内容:

@echo off
timeout /t [延时时间(秒)]
start “” “[程序路径]”

其中,[延时时间(秒)]是你想要的延时时间,[程序路径]是你要启动的程序的完整路径。
例如,如果你想要延时10秒启动程序,程序的完整路径是"C:\Program Files\Example\example.exe",那么批处理文件的内容应该是:

@echo off
timeout /t 10
start “” “C:\Program Files\Example\example.exe”

2) 将文件保存为批处理文件(以.bat为扩展名),例如"delayed_startup.bat"

3) 将批处理文件或其快捷方式移动到Windows的启动文件夹中

启动文件夹的路径通常是:
C:\Users[用户名]\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup
其中,[用户名]是你的Windows用户名。
或者通过在“运行”中执行命令“shell:startup”也可以打开“启动文件夹”

30、EXCEL中提取单元格内容内多行文本的第一行

1) 换行符

CHAR(10)

2) 判断是否有换行符

ISERROR(FIND(CHAR(10),A1))

假如没有换行符,此判断将返回true

3) 提取第一行内容

LEFT(A1,FIND(CHAR(10),A1)-1)

4) 判断是否有换行符,假如有则提取第一行内容,否则获取全部内容

IF(ISERROR(FIND(CHAR(10),A1)),A1,LEFT(A1,FIND(CHAR(10),A1)-1))

31、RSLinx内为PLC通信模块添加ip地址

添加ip

添加成功

32、ipv4设为静态地址,系统却使用自动配置的ipv4地址

现象

可能原因:
此ip地址已被路由器分配出去,导致不可用,此时需修改为不冲突的地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容