Joomla 3.1.5自带模块的数据库,sql忽略

时间:2013-10-04 05:48:39

标签: php joomla joomla3.1

我尝试为Joomla 3.1.5创建简单模块

模块没有问题安装但sql安装文件中的代码被忽略。当我卸载模块卸载脚本工作时。

我在instalaction sql中的代码

CREATE TABLE IF NOT EXISTS `#__mylist_songs`(
`song_id` int(11) not null auto_increment PRIMARY KEY,
`name` varchar(255) not null,
`author` varchar(150) not null
)Engine=MyIsam  default charset=utf8;

CREATE TABLE IF NOT EXISTS `#__mylist_vote`(
`vote_id` int(11) not null auto_increment PRIMARY KEY,
`song_id` int(11) not null,
`ip` varchar(26),
`vote_date` datetime not null default '0000-00-00 00:00:00'
)Engine=MyIsam  default charset=utf8;
模块xml中的

 <install>
        <sql>
            <file driver="mysql" charset="utf8">sql/mysql/install.mysql.utf8.sql</file>
        </sql>
    </install> <files>

        <filename module="mod_mylist">mod_mylist.php</filename>
        <filename>script.php</filename>
        <folder>tmpl</folder>
        <filename>helper.php</filename>
        <filename>index.html</filename>
        <filename>mod_mylist.xml</filename>
        <filename>sql/mysql/install.mysql.utf8.sql</filename>
        <filename>sql/mysql/uninstall.mysql.utf8.sql</filename>
        <folder>sql</folder>
        <folder>sql/mysql</folder>
        <folder>sql/mysql/updates</folder>
    </files>
    <scriptfile>script.php</scriptfile>

但是在DB中安装模块后没有改变。当我在卸载sql脚本joomla show错误时出现语法错误,但是在安装安装完成时没有错误。

我不明白为什么。路径是正确的我检查了它。

2 个答案:

答案 0 :(得分:0)

试试这个,

 <install>
            <sql>
                <file charset="utf8" driver="mysql">sql/mysql/install.sql</file>
            </sql>
        </install>
    <uninstall>
            <sql>
                <file charset="utf8" driver="mysql">sql/mysql/uninstall.sql</file>
            </sql>
        </uninstall>

install.sql文件应该有查询。还要确保DB用户有权添加新表。对于more

希望它的帮助..

答案 1 :(得分:0)

尝试将以下内容用于XML:

<files>
    <filename module="mod_mylist">mod_mylist.php</filename>
    <filename>index.html</filename>
    <filename>helper.php</filename>
    <folder>tmpl</folder>
    <folder>sql</folder>
</files>

我删除了对实际SQL文件的引用,因为如果您在<install>标记中调用它们并清理其余部分,则不需要定义它们。