index.uts 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. import Cursor from 'android.database.Cursor';
  2. import SQLiteDatabase from 'android.database.sqlite.SQLiteDatabase';
  3. import SQLiteOpenHelper from 'android.database.sqlite.SQLiteOpenHelper';
  4. import { createSQLiteContextOptions, executeSqlOptions, selectSqlOptions, executeSqlOptionsResult, selectSqlOptionsResult, CreateSQLiteContext, transactionOptions, transactionResult } from '../interface.uts';
  5. import { createSQLiteContextFailImpl } from '../unierror.uts';
  6. class SQLiteContext extends SQLiteOpenHelper {
  7. private dbName: string | null;
  8. constructor(name: string) {
  9. let version = 1;
  10. super(UTSAndroid.getAppContext()!, name, null, version.toInt());
  11. this.dbName = name;
  12. }
  13. public executeSql(options: executeSqlOptions) {
  14. const database: SQLiteDatabase = this.getReadableDatabase();
  15. const SqlArray = options.sql.split(';');
  16. let result: executeSqlOptionsResult = {
  17. data: [] as boolean[],
  18. errMsg: 'executeSql:ok',
  19. errSubject: '',
  20. errCode: 0,
  21. cause: null
  22. }
  23. try {
  24. for (let i = 0; i < SqlArray.length; i++) {
  25. if (SqlArray[i].length > 0) {
  26. const sql = SqlArray[i].replace(/^\s+/, '');
  27. try {
  28. database.execSQL(sql);
  29. result.data.push(true);
  30. } catch {
  31. result.data.push(false);
  32. }
  33. }
  34. }
  35. options.success?.(result);
  36. } catch (e) {
  37. const data = result.data;
  38. result = new createSQLiteContextFailImpl(1000002);
  39. result.data = data;
  40. options.fail?.(result);
  41. }
  42. options.complete?.(result);
  43. return result;
  44. }
  45. public selectSql(options: selectSqlOptions) {
  46. const database: SQLiteDatabase = this.getReadableDatabase();
  47. const SqlArray = options.sql.split(';');
  48. let result: selectSqlOptionsResult = {
  49. data: [] as string[],
  50. errMsg: 'selectSql:ok',
  51. errCode: 0,
  52. errSubject: '',
  53. cause: null
  54. }
  55. try {
  56. for (let i = 0; i < SqlArray.length; i++) {
  57. if (SqlArray[i].length > 0) {
  58. const sql = SqlArray[i].replace(/^\s+/, '');
  59. try {
  60. const cursor: Cursor = database.rawQuery(sql, null);
  61. //获取查询结果的字符串并push到result.data中
  62. if (cursor.moveToFirst()) {
  63. do {
  64. const row = cursor.getColumnCount();
  65. //const rowArray = [] as string[];
  66. for (let j = 0; j < row; j++) {
  67. result.data.push(cursor.getString(j));
  68. }
  69. //result.data.push(rowArray);
  70. } while (cursor.moveToNext());
  71. }
  72. cursor.close();
  73. } catch {
  74. result.data.push("");
  75. }
  76. }
  77. }
  78. options.success?.(result);
  79. } catch (e) {
  80. const data = result.data;
  81. result = new createSQLiteContextFailImpl(1000003);
  82. result.data = data;
  83. options.fail?.(result);
  84. }
  85. options.complete?.(result);
  86. return result;
  87. }
  88. public transaction(options: transactionOptions) {
  89. const database: SQLiteDatabase = this.getReadableDatabase();
  90. const transaction = options.operation;
  91. let result: transactionResult = {
  92. errMsg: 'transaction:ok',
  93. data: [],
  94. errCode: 0,
  95. errSubject: '',
  96. cause: null
  97. }
  98. try {
  99. if (transaction == 'begin') {
  100. //开启事务
  101. database.execSQL('BEGIN TRANSACTION');
  102. } else if (transaction == 'commit') {
  103. //提交事务
  104. database.execSQL('COMMIT');
  105. } else if (transaction == 'rollback') {
  106. //回滚事务
  107. database.execSQL('ROLLBACK');
  108. }
  109. options.success?.(result);
  110. } catch (e) {
  111. let errCode = 1000008;
  112. if (transaction == 'begin') {
  113. errCode = 1000004;
  114. } else if (transaction == 'commit') {
  115. errCode = 1000005;
  116. } else if (transaction == 'rollback') {
  117. errCode = 1000006;
  118. }
  119. result = new createSQLiteContextFailImpl(errCode);
  120. options.fail?.(result);
  121. }
  122. options.complete?.(result);
  123. return result;
  124. }
  125. }
  126. export const createSQLiteContext: CreateSQLiteContext = function (options: createSQLiteContextOptions) {
  127. const name = options.name + '.db';
  128. return new SQLiteContext(name);
  129. }