-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathlearnbase.h
87 lines (69 loc) · 3.76 KB
/
learnbase.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#ifndef LEARNBASE_H
#define LEARNBASE_H
#include "mysqlite.h"
class LearnBase : public MySQLite
{
public:
LearnBase(const QString &dbpath, const QString &connName);
~LearnBase();
protected:
void createStateTable();
void createCurrTimeStateTable();
public:
QSqlDatabase *getLearnStatedb();
bool addNewWordState(const QString &tableName,const QString &bookPath,
const int &wid,const QString &word,const QString &mean,
const QString &connection,const int &lektion,
const double &EF,const int &Grade, const int &Repetition, const int &Interval);
int isExist(const QString &tableName,const QString &bookPath,
const int &wid);
int isExist(const QString &tableName,const QString &bookPath);
void deleteTable(const QString &tableName);
bool deleteRecord(const QString &tableName,const int &id);
bool deleteRecord(const QString &tableName,const QString &bookPath);
QList<int> getReviewWordIDByLektion(const QString &tableName,
const QString &bookPath,
const int &lektion);
QList<int> getReviewWordID(const QString &tableName,
const QString &bookPath);
QStringList getImportantInfo(const QString &tableName,const int &id);
int getRecordCount(const QString &tableName);
QString getLastTime(const QString &tableName,const int &id);
QString getWord(const QString &tableName,const int &id);
QString getMean(const QString &tableName,const int &id);
QString getConnection(const QString &tableName,const int &id);
int getLektion(const QString &tableName,const int &id);
QStringList getWordAll(const QString &tableName,const int &id);
QList<QString> getWordState(const QString &tableName,const int &id);
int getGrade(const QString &tableName,const int &id);
double getEF(const QString &tableName,const int &id);
int getRepetition(const QString &tableName,const int &id);
int getInterval(const QString &tableName,const int &id);
int getTimeDiff(const QString &tableName,const int &id);
bool setWordAll(const QString &tableName,const int &wid,
const QString &bookPath,const QStringList &wordall);
bool setWord(const QString &tableName,const int &wid,
const QString &bookPath,const QString &word);
bool setMean(const QString &tableName,const int &wid,
const QString &bookPath,const QString &mean);
bool setConnection(const QString &tableName,const int &wid,
const QString &bookPath,const QString &connection);
bool setLektion(const QString &tableName,const int &wid,
const QString &bookPath,const int &lektion);
bool setWordState(const QString &tableName,const int &id,const int &Grade,
const double &EF,const int &Repetition,const int &Interval);
bool setGrade(const QString &tableName,const int &id,const int &Grade);
bool setEF(const QString &tableName,const int &id,const double &EF);
bool setRepetition(const QString &tableName,const int &id,const int &Repetition);
bool setInterval(const QString &tableName,const int &id,const int &Interval);
bool setTimeDiff(const QString &tableName,const int &id,const int &TimeDiff);
int getHaveLearnedWordCountByLektion(const QString &bookPath,const int &lektion);
int getHaveLearnedWordCount(const QString &bookPath);
int getReviewCountInfo(const QString &bookPath,const int &Interval);
int getWordCountG5(const QString &bookPath);
int getWordCountG4A3(const QString &bookPath);
int getWordCountGU3(const QString &bookPath);
public:
QSqlTableModel *studyStateDBModel(QWidget *parent);
};
#endif // LEARNBASE_H