-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathselfoss_sqlite2mysql.php
More file actions
76 lines (63 loc) · 2.33 KB
/
selfoss_sqlite2mysql.php
File metadata and controls
76 lines (63 loc) · 2.33 KB
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
#!/usr/bin/php
<?php
chdir(__DIR__);
if ($argc != 5) {
echo 'Usage: '.$argv[0].' hostname database username password'."\n";
exit;
}
$sqlite_db = 'data/sqlite/selfoss.db';
$mysql_hostname = $argv[1];
$mysql_database = $argv[2];
$mysql_username = $argv[3];
$mysql_password = $argv[4];
$dbs = new SQLite3($sqlite_db);
$dbm = new mysqli($mysql_hostname, $mysql_username, $mysql_password, $mysql_database);
if ($dbm->connect_errno) {
printf("Connect failed: %s\n", $dbm->connect_error);
exit;
}
$dbs->query('SET NAMES utf8');
$count_items = 0;
$count_sources = 0;
$count_tags = 0;
$dbs_result = $dbs->query('SELECT * FROM items');
while($dbs_row = $dbs_result->fetchArray()) {
$dbm->query(sprintf(
"INSERT INTO items SET id = '%s', datetime = '%s', title = '%s', content = '%s', thumbnail = '%s', icon = '%s', unread = '%s', starred = '%s', source = '%s', uid = '%s', link = '%s'",
$dbm->real_escape_string($dbs_row['id']),
$dbm->real_escape_string($dbs_row['datetime']),
$dbm->real_escape_string($dbs_row['title']),
$dbm->real_escape_string($dbs_row['content']),
$dbm->real_escape_string($dbs_row['thumbnail']),
$dbm->real_escape_string($dbs_row['icon']),
$dbm->real_escape_string($dbs_row['unread']),
$dbm->real_escape_string($dbs_row['starred']),
$dbm->real_escape_string($dbs_row['source']),
$dbm->real_escape_string($dbs_row['uid']),
$dbm->real_escape_string($dbs_row['link'])
));
echo 'Items: '.++$count_items."\n";
}
$dbs_result = $dbs->query('SELECT * FROM sources');
while($dbs_row = $dbs_result->fetchArray()) {
$dbm->query(sprintf(
"INSERT INTO sources SET id = '%s', title = '%s', tags = '%s', spout = '%s', params = '%s', error = '%s', lastupdate = '%s'",
$dbm->real_escape_string($dbs_row['id']),
$dbm->real_escape_string($dbs_row['title']),
$dbm->real_escape_string($dbs_row['tags']),
$dbm->real_escape_string($dbs_row['spout']),
$dbm->real_escape_string($dbs_row['params']),
$dbm->real_escape_string($dbs_row['error']),
$dbm->real_escape_string($dbs_row['lastupdate'])
));
echo 'Sources: '.++$count_sources."\n";
}
$dbs_result = $dbs->query('SELECT * FROM tags');
while($dbs_row = $dbs_result->fetchArray()) {
$dbm->query(sprintf(
"INSERT INTO tags SET tag = '%s', color = '%s'",
$dbm->real_escape_string($dbs_row['tag']),
$dbm->real_escape_string($dbs_row['color'])
));
echo 'Tags: '.++$count_tags."\n";
}