several SQLite compatability improvements, as suggested by naikoto on the forums
git-svn-id: file:///home/shish/svn/shimmie2/trunk@680 7f39781d-f577-437e-ae19-be835c7a54ca
This commit is contained in:
parent
bcca76969e
commit
19d80a244f
5 changed files with 90 additions and 119 deletions
|
@ -16,6 +16,7 @@ class Image {
|
||||||
public function Image($row=null) {
|
public function Image($row=null) {
|
||||||
if(!is_null($row)) {
|
if(!is_null($row)) {
|
||||||
foreach($row as $name => $value) {
|
foreach($row as $name => $value) {
|
||||||
|
// FIXME: some databases use table.name rather than name
|
||||||
$this->$name = $value; // hax
|
$this->$name = $value; // hax
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +31,7 @@ class Image {
|
||||||
if(!isset($this->tag_array)) {
|
if(!isset($this->tag_array)) {
|
||||||
global $database;
|
global $database;
|
||||||
$this->tag_array = Array();
|
$this->tag_array = Array();
|
||||||
$row = $database->Execute("SELECT * FROM image_tags JOIN tags ON image_tags.tag_id = tags.id WHERE image_id=? ORDER BY tag", array($this->id));
|
$row = $database->Execute("SELECT tag FROM image_tags JOIN tags ON image_tags.tag_id = tags.id WHERE image_id=? ORDER BY tag", array($this->id));
|
||||||
while(!$row->EOF) {
|
while(!$row->EOF) {
|
||||||
$this->tag_array[] = $row->fields['tag'];
|
$this->tag_array[] = $row->fields['tag'];
|
||||||
$row->MoveNext();
|
$row->MoveNext();
|
||||||
|
|
|
@ -167,7 +167,7 @@ class TagList extends Extension {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
$query = "
|
$query = "
|
||||||
SELECT COUNT(it3.image_id) as count, t3.tag
|
SELECT COUNT(it3.image_id) as count, t3.tag AS tag
|
||||||
FROM
|
FROM
|
||||||
image_tags AS it1,
|
image_tags AS it1,
|
||||||
image_tags AS it2,
|
image_tags AS it2,
|
||||||
|
@ -183,7 +183,7 @@ class TagList extends Extension {
|
||||||
AND t1.id = it1.tag_id
|
AND t1.id = it1.tag_id
|
||||||
AND t3.id = it3.tag_id
|
AND t3.id = it3.tag_id
|
||||||
GROUP BY it3.tag_id
|
GROUP BY it3.tag_id
|
||||||
ORDER BY count DESC
|
ORDER BY count(it3.image_id) DESC
|
||||||
LIMIT ?
|
LIMIT ?
|
||||||
";
|
";
|
||||||
$args = array($image->id, $config->get_int('tag_list_length'));
|
$args = array($image->id, $config->get_int('tag_list_length'));
|
||||||
|
@ -230,7 +230,7 @@ class TagList extends Extension {
|
||||||
|
|
||||||
if($tags_ok) {
|
if($tags_ok) {
|
||||||
$query = "
|
$query = "
|
||||||
SELECT t2.tag, COUNT(it2.image_id) AS count
|
SELECT t2.tag AS tag, COUNT(it2.image_id) AS count
|
||||||
FROM
|
FROM
|
||||||
image_tags AS it1,
|
image_tags AS it1,
|
||||||
image_tags AS it2,
|
image_tags AS it2,
|
||||||
|
@ -242,7 +242,7 @@ class TagList extends Extension {
|
||||||
AND it1.tag_id = t1.id
|
AND it1.tag_id = t1.id
|
||||||
AND it2.tag_id = t2.id
|
AND it2.tag_id = t2.id
|
||||||
GROUP BY t2.tag
|
GROUP BY t2.tag
|
||||||
ORDER BY count
|
ORDER BY count(it2.image_id)
|
||||||
DESC LIMIT ?
|
DESC LIMIT ?
|
||||||
";
|
";
|
||||||
$args = array($config->get_int('tag_list_length'));
|
$args = array($config->get_int('tag_list_length'));
|
||||||
|
|
|
@ -62,4 +62,8 @@ $user = _get_user();
|
||||||
send_event(new InitExtEvent());
|
send_event(new InitExtEvent());
|
||||||
send_event(_get_page_request($page, $user));
|
send_event(_get_page_request($page, $user));
|
||||||
$page->display();
|
$page->display();
|
||||||
|
|
||||||
|
|
||||||
|
// for databases which support transactions
|
||||||
|
$database->db->CommitTrans(true);
|
||||||
?>
|
?>
|
||||||
|
|
171
install.php
171
install.php
|
@ -492,145 +492,92 @@ function move_data($old_dsn, $new_dsn, $old_data) {
|
||||||
* Note: try and keep this as ANSI SQL compliant as possible,
|
* Note: try and keep this as ANSI SQL compliant as possible,
|
||||||
* so that we can (in theory) support other databases
|
* so that we can (in theory) support other databases
|
||||||
*/
|
*/
|
||||||
function create_tables_mysql($db) {
|
function create_tables_common($db, $auto_incrementing_id, $boolean, $true, $false, $ip) {
|
||||||
$db->StartTrans();
|
|
||||||
|
|
||||||
$db->Execute("SET NAMES utf8"); // FIXME: mysql-specific :(
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE aliases (
|
$db->Execute("CREATE TABLE aliases (
|
||||||
oldtag varchar(255) NOT NULL,
|
oldtag VARCHAR(255) NOT NULL PRIMARY KEY,
|
||||||
newtag varchar(255) NOT NULL,
|
newtag VARCHAR(255) NOT NULL
|
||||||
PRIMARY KEY (oldtag)
|
|
||||||
)");
|
)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE config (
|
$db->Execute("CREATE TABLE config (
|
||||||
name varchar(255) NOT NULL,
|
name VARCHAR(255) NOT NULL PRIMARY KEY,
|
||||||
value text,
|
value TEXT
|
||||||
PRIMARY KEY (name)
|
|
||||||
)");
|
)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE images (
|
$db->Execute("CREATE TABLE images (
|
||||||
id int(11) NOT NULL auto_increment,
|
id $auto_incrementing_id,
|
||||||
owner_id int(11) NOT NULL default '0',
|
owner_id INTEGER NOT NULL,
|
||||||
owner_ip char(16) default NULL,
|
owner_ip $ip,
|
||||||
filename varchar(64) NOT NULL default '',
|
filename VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
filesize int(11) NOT NULL default '0',
|
filesize INTEGER NOT NULL,
|
||||||
hash char(32) NOT NULL default '',
|
hash CHAR(32) NOT NULL UNIQUE,
|
||||||
ext char(4) NOT NULL default '',
|
ext CHAR(4) NOT NULL,
|
||||||
source varchar(255),
|
source VARCHAR(255),
|
||||||
width int(11) NOT NULL,
|
width INTEGER NOT NULL,
|
||||||
height int(11) NOT NULL,
|
height INTEGER NOT NULL,
|
||||||
posted datetime NOT NULL,
|
posted TIMESTAMP NOT NULL
|
||||||
PRIMARY KEY (id),
|
|
||||||
UNIQUE (hash)
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE tags (
|
|
||||||
id int not null auto_increment primary key,
|
|
||||||
tag varchar(64) not null unique,
|
|
||||||
count int not null default 0,
|
|
||||||
KEY tags_count(count)
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE image_tags (
|
|
||||||
image_id int NOT NULL default 0,
|
|
||||||
tag_id int NOT NULL default 0,
|
|
||||||
UNIQUE KEY image_id_tag_id (image_id,tag_id),
|
|
||||||
KEY tags_tag_id (tag_id),
|
|
||||||
KEY tags_image_id (image_id)
|
|
||||||
)");
|
)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE users (
|
$db->Execute("CREATE TABLE users (
|
||||||
id int(11) NOT NULL auto_increment,
|
id $auto_incrementing_id,
|
||||||
name varchar(32) NOT NULL,
|
name VARCHAR(32) NOT NULL UNIQUE,
|
||||||
pass char(32) default NULL,
|
pass CHAR(32),
|
||||||
joindate datetime NOT NULL,
|
joindate DATETIME NOT NULL,
|
||||||
enabled enum('N','Y') NOT NULL default 'Y',
|
enabled $boolean NOT NULL DEFAULT $true,
|
||||||
admin enum('N','Y') NOT NULL default 'N',
|
admin $boolean NOT NULL DEFAULT $false,
|
||||||
email varchar(255) default NULL,
|
email VARCHAR(255)
|
||||||
PRIMARY KEY (id),
|
|
||||||
UNIQUE (name)
|
|
||||||
)");
|
)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE layout (
|
$db->Execute("CREATE TABLE layout (
|
||||||
title varchar(64) primary key not null,
|
title VARCHAR(64) PRIMARY KEY NOT NULL,
|
||||||
section varchar(32) not null default \"left\",
|
section VARCHAR(32) NOT NULL DEFAULT 'left',
|
||||||
position int not null default 50,
|
position INTEGER NOT NULL DEFAULT 50,
|
||||||
visible enum('Y', 'N') default 'Y' not null
|
visible $boolean DEFAULT $true
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("INSERT INTO config(name, value) VALUES(?, ?)", Array('db_version', 5));
|
|
||||||
|
|
||||||
return $db->CommitTrans();
|
|
||||||
}
|
|
||||||
function create_tables_pgsql($db) {
|
|
||||||
$db->StartTrans();
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE aliases (
|
|
||||||
oldtag varchar(255) NOT NULL,
|
|
||||||
newtag varchar(255) NOT NULL,
|
|
||||||
PRIMARY KEY (oldtag)
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE config (
|
|
||||||
name varchar(255) NOT NULL,
|
|
||||||
value text,
|
|
||||||
PRIMARY KEY (name)
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE images (
|
|
||||||
id SERIAL NOT NULL,
|
|
||||||
owner_id integer NOT NULL default '0',
|
|
||||||
owner_ip char(16) default NULL,
|
|
||||||
filename varchar(64) NOT NULL default '',
|
|
||||||
filesize integer NOT NULL default '0',
|
|
||||||
hash char(32) NOT NULL default '',
|
|
||||||
ext char(4) NOT NULL default '',
|
|
||||||
source varchar(255),
|
|
||||||
width integer NOT NULL,
|
|
||||||
height integer NOT NULL,
|
|
||||||
posted timestamp NOT NULL,
|
|
||||||
PRIMARY KEY (id),
|
|
||||||
UNIQUE (hash)
|
|
||||||
)");
|
)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE tags (
|
$db->Execute("CREATE TABLE tags (
|
||||||
id SERIAL NOT NULL,
|
id $auto_incrementing_id,
|
||||||
tag varchar(64) not null unique,
|
tag VARCHAR(64) NOT NULL UNIQUE,
|
||||||
count int not null default 0,
|
count INTEGER NOT NULL DEFAULT 0
|
||||||
PRIMARY KEY(id)
|
|
||||||
)");
|
)");
|
||||||
$db->Execute("CREATE INDEX tags__count ON tags(count)");
|
$db->Execute("CREATE INDEX tags__count ON tags(count)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE image_tags (
|
$db->Execute("CREATE TABLE image_tags (
|
||||||
image_id int NOT NULL default 0,
|
image_id INTEGER NOT NULL DEFAULT 0,
|
||||||
tag_id int NOT NULL default 0,
|
tag_id INTEGER NOT NULL DEFAULT 0,
|
||||||
UNIQUE (image_id, tag_id)
|
UNIQUE (image_id, tag_id)
|
||||||
)");
|
)");
|
||||||
$db->Execute("CREATE INDEX image_tags__tag_id ON image_tags(tag_id)");
|
$db->Execute("CREATE INDEX image_tags__tag_id ON image_tags(tag_id)");
|
||||||
$db->Execute("CREATE INDEX image_tags__image_id ON image_tags(image_id)");
|
$db->Execute("CREATE INDEX image_tags__image_id ON image_tags(image_id)");
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE users (
|
|
||||||
id SERIAL NOT NULL,
|
|
||||||
name varchar(32) NOT NULL,
|
|
||||||
pass char(32) default NULL,
|
|
||||||
joindate timestamp NOT NULL,
|
|
||||||
enabled char(1) NOT NULL default 'Y',
|
|
||||||
admin char(1) NOT NULL default 'N',
|
|
||||||
email varchar(255) default NULL,
|
|
||||||
PRIMARY KEY (id),
|
|
||||||
UNIQUE (name)
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("CREATE TABLE layout (
|
|
||||||
title varchar(64) primary key not null,
|
|
||||||
section varchar(32) not null default 'left',
|
|
||||||
position int not null default 50,
|
|
||||||
visible char(1) default 'Y' not null
|
|
||||||
)");
|
|
||||||
|
|
||||||
$db->Execute("INSERT INTO config(name, value) VALUES(?, ?)", Array('db_version', 5));
|
$db->Execute("INSERT INTO config(name, value) VALUES(?, ?)", Array('db_version', 5));
|
||||||
|
}
|
||||||
|
function create_tables_mysql($db) {
|
||||||
|
$db->StartTrans();
|
||||||
|
$db->Execute("SET NAMES utf8");
|
||||||
|
create_tables_common($db,
|
||||||
|
"INTEGER NOT NULL AUTO_INCREMENT PRIMARY KEY",
|
||||||
|
"ENUM('Y', 'N')", "'Y'", "'N'",
|
||||||
|
"CHAR(15)"
|
||||||
|
);
|
||||||
|
return $db->CommitTrans();
|
||||||
|
}
|
||||||
|
function create_tables_pgsql($db) {
|
||||||
|
$db->StartTrans();
|
||||||
|
create_tables_common($db,
|
||||||
|
"SERIAL NOT NULL PRIMARY KEY",
|
||||||
|
"BOOLEAN", "True", "False",
|
||||||
|
"INET"
|
||||||
|
);
|
||||||
|
return $db->CommitTrans();
|
||||||
|
}
|
||||||
|
function create_tables_sqlite($db) {
|
||||||
|
$db->StartTrans();
|
||||||
|
create_tables_common($db,
|
||||||
|
"INTEGER AUTOINCREMENT PRIMARY KEY NOT NULL",
|
||||||
|
"CHAR(1)", "'Y'", "'N'",
|
||||||
|
"CHAR(15)"
|
||||||
|
);
|
||||||
return $db->CommitTrans();
|
return $db->CommitTrans();
|
||||||
}
|
}
|
||||||
// }}}
|
// }}}
|
||||||
|
|
|
@ -152,6 +152,15 @@ class ADODB_sqlite extends ADOConnection {
|
||||||
{
|
{
|
||||||
@sqlite_create_function($this->_connectionID, 'adodb_date', 'adodb_date', 1);
|
@sqlite_create_function($this->_connectionID, 'adodb_date', 'adodb_date', 1);
|
||||||
@sqlite_create_function($this->_connectionID, 'adodb_date2', 'adodb_date2', 2);
|
@sqlite_create_function($this->_connectionID, 'adodb_date2', 'adodb_date2', 2);
|
||||||
|
|
||||||
|
// XXX: shimmie customisation, as suggested by naikoto on the forums
|
||||||
|
@sqlite_create_function($this->_connectionID, 'UNIX_TIMESTAMP', 'UNIX_TIMESTAMP', 1);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'now', 'now', 0);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'floor', 'mfloor', 1);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'log', 'mlog', 1);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'isnull', 'fisnull', 1);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'md5', 'fmd5', 1);
|
||||||
|
@sqlite_create_function($this->_connectionID, 'concat', 'fconcat', 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -395,4 +404,14 @@ class ADORecordset_sqlite extends ADORecordSet {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// shimmie functions
|
||||||
|
ini_set ( 'sqlite.assoc_case' , 0 );
|
||||||
|
function UNIX_TIMESTAMP($date) { return strtotime($date); }
|
||||||
|
function now() { return date("Y-m-d h:i:s"); }
|
||||||
|
function mfloor($a) { return floor($a); }
|
||||||
|
function mlog($a) { return log($a); }
|
||||||
|
function fisnull($a) { return is_null($a); }
|
||||||
|
function fmd5($a) { return md5($a); }
|
||||||
|
function fconcat($a, $b) { return $a . $b; }
|
||||||
?>
|
?>
|
Reference in a new issue