MOBILE-4270 db: Tweaks on sqlite
This commit is contained in:
		
							parent
							
								
									c22424c93e
								
							
						
					
					
						commit
						51bd21163a
					
				| @ -174,7 +174,8 @@ export class SQLiteDB { | |||||||
|             sql = equal ? '= ?' : '<> ?'; |             sql = equal ? '= ?' : '<> ?'; | ||||||
|             params = Array.isArray(items) ? items : [items]; |             params = Array.isArray(items) ? items : [items]; | ||||||
|         } else { |         } else { | ||||||
|             sql = (equal ? '' : 'NOT ') + 'IN (' + ',?'.repeat(items.length).substring(1) + ')'; |             const questionMarks = ',?'.repeat(items.length).substring(1); | ||||||
|  |             sql = (equal ? '' : 'NOT ') + `IN (${questionMarks})`; | ||||||
|             params = items; |             params = items; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -237,7 +238,7 @@ export class SQLiteDB { | |||||||
|         tableCheck?: string, |         tableCheck?: string, | ||||||
|     ): string { |     ): string { | ||||||
|         const columnsSql: string[] = []; |         const columnsSql: string[] = []; | ||||||
|         let sql = `CREATE TABLE IF NOT EXISTS ${name} (`; |         let tableStructureSQL = ''; | ||||||
| 
 | 
 | ||||||
|         // First define all the columns.
 |         // First define all the columns.
 | ||||||
|         for (const index in columns) { |         for (const index in columns) { | ||||||
| @ -245,7 +246,7 @@ export class SQLiteDB { | |||||||
|             let columnSql: string = column.name || ''; |             let columnSql: string = column.name || ''; | ||||||
| 
 | 
 | ||||||
|             if (column.type) { |             if (column.type) { | ||||||
|                 columnSql += ' ' + column.type; |                 columnSql += ` ${column.type}`; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (column.primaryKey) { |             if (column.primaryKey) { | ||||||
| @ -273,25 +274,25 @@ export class SQLiteDB { | |||||||
| 
 | 
 | ||||||
|             columnsSql.push(columnSql); |             columnsSql.push(columnSql); | ||||||
|         } |         } | ||||||
|         sql += columnsSql.join(', '); |         tableStructureSQL += columnsSql.join(', '); | ||||||
| 
 | 
 | ||||||
|         // Now add the table constraints.
 |         // Now add the table constraints.
 | ||||||
| 
 | 
 | ||||||
|         if (primaryKeys && primaryKeys.length) { |         if (primaryKeys && primaryKeys.length) { | ||||||
|             sql += `, PRIMARY KEY (${primaryKeys.join(', ')})`; |             tableStructureSQL += `, PRIMARY KEY (${primaryKeys.join(', ')})`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (uniqueKeys && uniqueKeys.length) { |         if (uniqueKeys && uniqueKeys.length) { | ||||||
|             for (const index in uniqueKeys) { |             for (const index in uniqueKeys) { | ||||||
|                 const setOfKeys = uniqueKeys[index]; |                 const setOfKeys = uniqueKeys[index]; | ||||||
|                 if (setOfKeys && setOfKeys.length) { |                 if (setOfKeys && setOfKeys.length) { | ||||||
|                     sql += `, UNIQUE (${setOfKeys.join(', ')})`; |                     tableStructureSQL += `, UNIQUE (${setOfKeys.join(', ')})`; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (tableCheck) { |         if (tableCheck) { | ||||||
|             sql += `, CHECK (${tableCheck})`; |             tableStructureSQL += `, CHECK (${tableCheck})`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         for (const index in foreignKeys) { |         for (const index in foreignKeys) { | ||||||
| @ -301,18 +302,18 @@ export class SQLiteDB { | |||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             sql += `, FOREIGN KEY (${foreignKey.columns.join(', ')}) REFERENCES ${foreignKey.table} `; |             tableStructureSQL += `, FOREIGN KEY (${foreignKey.columns.join(', ')}) REFERENCES ${foreignKey.table} `; | ||||||
| 
 | 
 | ||||||
|             if (foreignKey.foreignColumns && foreignKey.foreignColumns.length) { |             if (foreignKey.foreignColumns && foreignKey.foreignColumns.length) { | ||||||
|                 sql += `(${foreignKey.foreignColumns.join(', ')})`; |                 tableStructureSQL += `(${foreignKey.foreignColumns.join(', ')})`; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (foreignKey.actions) { |             if (foreignKey.actions) { | ||||||
|                 sql += ` ${foreignKey.actions}`; |                 tableStructureSQL += ` ${foreignKey.actions}`; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return sql + ')'; |         return `CREATE TABLE IF NOT EXISTS ${name} (${tableStructureSQL})`; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -355,7 +356,7 @@ export class SQLiteDB { | |||||||
|         countItem: string = 'COUNT(\'x\')', |         countItem: string = 'COUNT(\'x\')', | ||||||
|     ): Promise<number> { |     ): Promise<number> { | ||||||
|         if (select) { |         if (select) { | ||||||
|             select = 'WHERE ' + select; |             select = `WHERE ${select}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return this.countRecordsSql(`SELECT ${countItem} FROM ${table} ${select}`, params); |         return this.countRecordsSql(`SELECT ${countItem} FROM ${table} ${select}`, params); | ||||||
| @ -470,7 +471,7 @@ export class SQLiteDB { | |||||||
|      */ |      */ | ||||||
|     async deleteRecordsSelect(table: string, select: string = '', params?: SQLiteDBRecordValue[]): Promise<number> { |     async deleteRecordsSelect(table: string, select: string = '', params?: SQLiteDBRecordValue[]): Promise<number> { | ||||||
|         if (select) { |         if (select) { | ||||||
|             select = 'WHERE ' + select; |             select = `WHERE ${select}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const result = await this.execute(`DELETE FROM ${table} ${select}`, params); |         const result = await this.execute(`DELETE FROM ${table} ${select}`, params); | ||||||
| @ -529,22 +530,8 @@ export class SQLiteDB { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // Remove undefined entries and convert null to "NULL".
 |         // Remove undefined entries.
 | ||||||
|         for (const name in data) { |         Object.keys(data).forEach(key => data[key] === undefined && delete data[key]); | ||||||
|             if (data[name] === undefined) { |  | ||||||
|                 delete data[name]; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Format the data to where params. |  | ||||||
|      * |  | ||||||
|      * @param data Object data. |  | ||||||
|      * @returns List of params. |  | ||||||
|      */ |  | ||||||
|     protected formatDataToSQLParams(data: SQLiteDBRecordValues): SQLiteDBRecordValue[] { |  | ||||||
|         return Object.values(data).map((value) => value as SQLiteDBRecordValue); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -587,7 +574,7 @@ export class SQLiteDB { | |||||||
|         params?: SQLiteDBRecordValue[], |         params?: SQLiteDBRecordValue[], | ||||||
|     ): Promise<SQLiteDBRecordValue> { |     ): Promise<SQLiteDBRecordValue> { | ||||||
|         if (select) { |         if (select) { | ||||||
|             select = 'WHERE ' + select; |             select = `WHERE ${select}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return this.getFieldSql(`SELECT ${field} FROM ${table} ${select}`, params); |         return this.getFieldSql(`SELECT ${field} FROM ${table} ${select}`, params); | ||||||
| @ -648,7 +635,7 @@ export class SQLiteDB { | |||||||
|         fields: string = '*', |         fields: string = '*', | ||||||
|     ): Promise<T> { |     ): Promise<T> { | ||||||
|         if (select) { |         if (select) { | ||||||
|             select = ' WHERE ' + select; |             select = ` WHERE ${select}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return this.getRecordSql<T>(`SELECT ${fields} FROM ${table} ${select}`, params); |         return this.getRecordSql<T>(`SELECT ${fields} FROM ${table} ${select}`, params); | ||||||
| @ -746,10 +733,10 @@ export class SQLiteDB { | |||||||
|         limitNum: number = 0, |         limitNum: number = 0, | ||||||
|     ): Promise<T[]> { |     ): Promise<T[]> { | ||||||
|         if (select) { |         if (select) { | ||||||
|             select = ' WHERE ' + select; |             select = ` WHERE ${select}`; | ||||||
|         } |         } | ||||||
|         if (sort) { |         if (sort) { | ||||||
|             sort = ' ORDER BY ' + sort; |             sort = ` ORDER BY ${sort}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const sql = `SELECT ${fields} FROM ${table} ${select} ${sort}`; |         const sql = `SELECT ${fields} FROM ${table} ${select} ${sort}`; | ||||||
| @ -778,7 +765,7 @@ export class SQLiteDB { | |||||||
|             if (limits[1] < 1) { |             if (limits[1] < 1) { | ||||||
|                 limits[1] = Number.MAX_VALUE; |                 limits[1] = Number.MAX_VALUE; | ||||||
|             } |             } | ||||||
|             sql += ' LIMIT ' + limits[0] + ', ' + limits[1]; |             sql += ` LIMIT ${limits[0]}, ${limits[1]}`; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const result = await this.execute(sql, params); |         const result = await this.execute(sql, params); | ||||||
| @ -807,7 +794,7 @@ export class SQLiteDB { | |||||||
| 
 | 
 | ||||||
|         return { |         return { | ||||||
|             sql: `INSERT OR REPLACE INTO ${table} (${fields}) VALUES (${questionMarks})`, |             sql: `INSERT OR REPLACE INTO ${table} (${fields}) VALUES (${questionMarks})`, | ||||||
|             params: this.formatDataToSQLParams(data), |             params: Object.values(data), | ||||||
|         }; |         }; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -897,7 +884,7 @@ export class SQLiteDB { | |||||||
|     ): Promise<void> { |     ): Promise<void> { | ||||||
|         try { |         try { | ||||||
|             await this.tableExists(oldTable); |             await this.tableExists(oldTable); | ||||||
|         } catch (error) { |         } catch { | ||||||
|             // Old table does not exist, ignore.
 |             // Old table does not exist, ignore.
 | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @ -919,7 +906,7 @@ export class SQLiteDB { | |||||||
| 
 | 
 | ||||||
|         try { |         try { | ||||||
|             await this.dropTable(oldTable); |             await this.dropTable(oldTable); | ||||||
|         } catch (error) { |         } catch { | ||||||
|             // Error deleting old table, ignore.
 |             // Error deleting old table, ignore.
 | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -1066,7 +1053,7 @@ export class SQLiteDB { | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // Create the list of params using the "data" object and the params for the where clause.
 |         // Create the list of params using the "data" object and the params for the where clause.
 | ||||||
|         let params = this.formatDataToSQLParams(data); |         let params = Object.values(data); | ||||||
|         if (where && whereParams) { |         if (where && whereParams) { | ||||||
|             params = params.concat(whereParams); |             params = params.concat(whereParams); | ||||||
|         } |         } | ||||||
| @ -1090,19 +1077,19 @@ export class SQLiteDB { | |||||||
|             }; |             }; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const where: string[] = []; |  | ||||||
|         const params: SQLiteDBRecordValue[] = []; |         const params: SQLiteDBRecordValue[] = []; | ||||||
| 
 | 
 | ||||||
|         for (const key in conditions) { |         const where = Object.keys(conditions).map((field) => { | ||||||
|             const value = conditions[key]; |             const value = conditions[field]; | ||||||
| 
 | 
 | ||||||
|             if (value === undefined || value === null) { |             if (value === undefined || value === null) { | ||||||
|                 where.push(key + ' IS NULL'); |                 return `${field} IS NULL`; | ||||||
|             } else { |  | ||||||
|                 where.push(key + ' = ?'); |  | ||||||
|                 params.push(value); |  | ||||||
|             } |             } | ||||||
|         } | 
 | ||||||
|  |             params.push(value); | ||||||
|  | 
 | ||||||
|  |             return `${field} = ?`; | ||||||
|  |         }); | ||||||
| 
 | 
 | ||||||
|         return { |         return { | ||||||
|             sql: where.join(' AND '), |             sql: where.join(' AND '), | ||||||
| @ -1130,7 +1117,7 @@ export class SQLiteDB { | |||||||
| 
 | 
 | ||||||
|         values.forEach((value) => { |         values.forEach((value) => { | ||||||
|             if (value === undefined || value === null) { |             if (value === undefined || value === null) { | ||||||
|                 sql = field + ' IS NULL'; |                 sql = `${field} IS NULL`; | ||||||
|             } else { |             } else { | ||||||
|                 params.push(value); |                 params.push(value); | ||||||
|             } |             } | ||||||
| @ -1138,14 +1125,14 @@ export class SQLiteDB { | |||||||
| 
 | 
 | ||||||
|         if (params && params.length) { |         if (params && params.length) { | ||||||
|             if (sql !== '') { |             if (sql !== '') { | ||||||
|                 sql = sql + ' OR '; |                 sql += ' OR '; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (params.length == 1) { |             if (params.length == 1) { | ||||||
|                 sql = sql + field + ' = ?'; |                 sql += `${field} = ?`; | ||||||
|             } else { |             } else { | ||||||
|                 const questionMarks = ',?'.repeat(params.length).substring(1); |                 const questionMarks = ',?'.repeat(params.length).substring(1); | ||||||
|                 sql = sql + field + ' IN (' + questionMarks + ')'; |                 sql += ` ${field} IN (${questionMarks})`; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -1232,7 +1219,7 @@ export class SQLiteDB { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export type SQLiteDBRecordValues = { | export type SQLiteDBRecordValues = { | ||||||
|     [key: string]: SQLiteDBRecordValue | undefined | null; |     [key: string]: SQLiteDBRecordValue; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export type SQLiteDBQueryParams = { | export type SQLiteDBQueryParams = { | ||||||
| @ -1240,4 +1227,4 @@ export type SQLiteDBQueryParams = { | |||||||
|     params: SQLiteDBRecordValue[]; |     params: SQLiteDBRecordValue[]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export type SQLiteDBRecordValue = number | string; | export type SQLiteDBRecordValue = number | string  | undefined | null; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user