Table of Contents

SQLite

SQLite

System.Data.SQLite

Note that the sqlite3 executable cannot access encrypted databases - that facility is a cost option.

Details of System.Data.SQLite can be found here
Note that this .NET assembly can access encrypted SQLite databases.

Copy data from one database to another

This is useful if you are using Unix, on Windows try using Cygwin.

$ echo ".dump" | ./sqlite3 p:/Data/Listener.sqlite | ./sqlite3 Listener1.sqlite

Date maths

Add a number of seconds to a date

This example converts a GMT datetime into datetime in the local timezone by adding (or subtracting if diffseconds is negative) the difference from GMT in seconds.

-- Server time when snapshot was taken
,datetime( julianday( c.Dttm ) + ( utc.DiffSeconds / 86400.0) ) as ServerDttm

Where c.Dttm is a column with datatype DateTime and DiffSeconds is numeric.
The julianday function returns a fractional number of days, we convert DiffSeconds to a fractional number of days by dividing by 86400.0
Note that the decimal value is required to force SQLite to use floating point arithmetic.

Format seconds as D:H:M:S

This example formats a process runtime (measured in seconds) as Days,Hours,Minutes and seconds.

 -- Uptime in format DDDD:HH:MI:SS. Substr is used to left pad days with zeroes
,substr('0000' || cast( c.RunSeconds/86400 as varchar ) || ':' || 
 time( ( c.RunSeconds - ( ( c.RunSeconds/86400)*86400 ) ), 'unixepoch' ), -13, 13 ) as Uptime

There is no LPAD or equivalent in SQLite so we use substr.