|
| 1 | +package testenv |
| 2 | + |
| 3 | +import "database/sql" |
| 4 | + |
| 5 | +var sqliteSchemas []schema = []schema{ |
| 6 | + { |
| 7 | + Create: ` |
| 8 | +CREATE TABLE go_TypeTest ( |
| 9 | + id INTEGER PRIMARY KEY AUTOINCREMENT, |
| 10 | + intTest INTEGER NOT NULL, |
| 11 | + tinyintTest INTEGER NOT NULL, |
| 12 | + smallIntTest INTEGER NOT NULL, |
| 13 | + bigIntTest INTEGER NOT NULL, |
| 14 | + unsignedTest INTEGER NOT NULL, |
| 15 | + varcharTest VARCHAR(10) NOT NULL, |
| 16 | + charTest CHAR(10) NOT NULL, |
| 17 | + charTextTest TEXT NOT NULL, |
| 18 | + dateTest DATE NOT NULL, |
| 19 | + dateTimeTest DATETIME NOT NULL, |
| 20 | + timestampTest TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 21 | + floatTest FLOAT NOT NULL, |
| 22 | + doubleTest DOUBLE NOT NULL, |
| 23 | + decimalTest DECIMAL(15, 10) NOT NULL, |
| 24 | + bitTest INTEGER NOT NULL, |
| 25 | +
|
| 26 | + nullIntTest INTEGER NULL, |
| 27 | + nullTinyintTest INTEGER NULL, |
| 28 | + nullSmallIntTest INTEGER NULL, |
| 29 | + nullBigIntTest INTEGER NULL, |
| 30 | + nullUnsignedTest INTEGER NULL, |
| 31 | + nullVarcharTest VARCHAR(10) NULL, |
| 32 | + nullCharTest CHAR(10) NULL, |
| 33 | + nullTextTest TEXT NULL, |
| 34 | + nullDateTest DATE NULL, |
| 35 | + nullDateTimeTest DATETIME NULL, |
| 36 | + nullTimestampTest TIMESTAMP NULL, |
| 37 | + nullFloatTest FLOAT NULL, |
| 38 | + nullDoubleTest DOUBLE NULL, |
| 39 | +
|
| 40 | + nullDecimalTest DECIMAL(15, 10) NULL, |
| 41 | + nullBitTest INTEGER NULL |
| 42 | +); |
| 43 | +`, |
| 44 | + Drop: `DROP TABLE go_TypeTest`, |
| 45 | + }, |
| 46 | + { |
| 47 | + Create: ` |
| 48 | +INSERT INTO go_TypeTest(intTest, tinyintTest, smallIntTest, bigIntTest, unsignedTest, varcharTest, charTest, charTextTest, dateTest, dateTimeTest, timestampTest, floatTest, doubleTest, decimalTest, bitTest) |
| 49 | +VALUES (1, 1, 1, 1, 1, '行1', '行1char', '行1text','2021-07-01','2021-07-01 15:38:50.425','2021-07-01 15:38:50.425', 1.456, 1.15678, '1.4567899900', 1); |
| 50 | +`, Drop: ``, |
| 51 | + }, |
| 52 | + { |
| 53 | + Create: ` |
| 54 | +INSERT INTO go_TypeTest(intTest, tinyintTest, smallIntTest, bigIntTest, unsignedTest, varcharTest, charTest, charTextTest, dateTest, dateTimeTest, timestampTest, floatTest, doubleTest, decimalTest, bitTest) |
| 55 | +VALUES (2, 2, 2, 2, 2, '行2', '行2char', '行2text', '2021-07-02', '2021-07-02 15:38:50.425','2021-07-02 15:38:50.425', 2.456, 2.15678, '2.4567899900', 1); |
| 56 | +`, |
| 57 | + Drop: ``, |
| 58 | + }, |
| 59 | + { |
| 60 | + Create: ` |
| 61 | +INSERT INTO go_TypeTest(intTest, tinyintTest, smallIntTest, bigIntTest, unsignedTest, varcharTest, charTest, charTextTest, dateTest, dateTimeTest, timestampTest, floatTest, doubleTest, decimalTest, bitTest, |
| 62 | + nullIntTest, nullTinyintTest, nullSmallIntTest, nullBigIntTest, nullUnsignedTest, nullVarcharTest, nullCharTest, nullTextTest, nullDateTest, nullDateTimeTest, nullTimestampTest, nullFloatTest, nullDoubleTest, nullDecimalTest, nullBitTest) |
| 63 | +VALUES (3, 3, 3, 3, 3, '行3', '行3char', '行3text', '2021-07-03', '2021-07-03 15:38:50.425','2021-07-03 15:38:50.425', 3.456, 3.15678, '3.4567899900', 1, |
| 64 | + 3, 3, 3, 3, 3, '行3', '行3char', '行3text', '2021-07-03', '2021-07-03 15:38:50.425','2021-07-03 15:38:50.425', 3.456, 3.15678, '3.4567899900', 1); |
| 65 | +`, |
| 66 | + Drop: ``, |
| 67 | + }, |
| 68 | + { |
| 69 | + Create: ` |
| 70 | +INSERT INTO go_TypeTest(intTest, tinyintTest, smallIntTest, bigIntTest, unsignedTest, varcharTest, charTest, charTextTest, dateTest, dateTimeTest, timestampTest, floatTest, doubleTest, decimalTest, bitTest, |
| 71 | + nullIntTest, nullTinyintTest, nullSmallIntTest, nullBigIntTest, nullUnsignedTest, nullVarcharTest, nullCharTest, nullTextTest, nullDateTest, nullDateTimeTest, nullTimestampTest, nullFloatTest, nullDoubleTest, nullDecimalTest, nullBitTest) |
| 72 | +VALUES (4, 4, 4, 4, 4, '行4', '行4char', '行4text', '2021-07-04', '2021-07-04 15:38:50.425','2021-07-04 15:38:50.425', 4.456, 4.15678, '4.4567899900', 0, |
| 73 | + 4, 4, 4, 4, 4, '行4', '行4char', '行4text', '2021-07-04', '2021-07-04 15:38:50.425','2021-07-04 15:38:50.425', 4.456, 4.15678, '4.4567899900', 0); |
| 74 | +`, |
| 75 | + Drop: ``, |
| 76 | + }, |
| 77 | +} |
| 78 | + |
| 79 | +// CreateSqliteSchema 用于初始化 Sqlite 的测试用表结构。 |
| 80 | +func CreateSqliteSchema(db *sql.DB) error { |
| 81 | + for _, schema := range sqliteSchemas { |
| 82 | + _, err := db.Exec(schema.Create) |
| 83 | + if err != nil { |
| 84 | + return err |
| 85 | + } |
| 86 | + } |
| 87 | + return nil |
| 88 | +} |
| 89 | + |
| 90 | +// DropSqliteSchema 用于初始化 Sqlite 的测试用表结构。 |
| 91 | +func DropSqliteSchema(db *sql.DB) error { |
| 92 | + for _, schema := range sqliteSchemas { |
| 93 | + if schema.Drop == "" { |
| 94 | + continue |
| 95 | + } |
| 96 | + _, err := db.Exec(schema.Drop) |
| 97 | + if err != nil { |
| 98 | + return err |
| 99 | + } |
| 100 | + } |
| 101 | + return nil |
| 102 | +} |
0 commit comments