我正在网站上加入多语言支持。 我可以使用Zend_Translate翻译字符串,但内容呢? 例如,我是否必须为每种语言为同一产品添加多条记录?或者还有其他方法吗? 我是多语种的新手,请帮忙。 提前谢谢。
---加法-----------------------------
好的,我决定使用混合解决方案来使用谷歌翻译api并将其存储在数据库中以供进一步编辑。那么存储翻译的数据库结构应该是什么?
我应该在相关表中保存记录
答案 0 :(得分:7)
几种可能的方法:
gettext
(或Poedit之类的软件)从内容中提取数据。可以使用变量插值。似乎第三种方法需要付出最大努力,但值得。
我假设您将产品数据存储在数据库中,如:
- product_data
-- id
-- price
-- name
-- description
-- etc…
所以你应该修改它,为每种语言的翻译字符串添加字段:
- product_data
-- id
-- price
- product_data_translations
-- product_id
-- language (e.g. en)
-- name
-- description
-- etc
然后,您可以轻松构建SQL查询以提取已翻译的数据where product_id=x and language="fr"
。
您也可以使用Doctrine I18N自动为您执行此操作。
您需要手动翻译内容(或使用Google API自动翻译),但是,您可以使用例如Zend_Search_Lucene轻松对其进行索引。