Ingen beskrivning

xormplus bd44e8fa80 Update README.md 10 år sedan
test 0b1e86c720 add test case 10 år sedan
.gitignore 52a602da39 Initial commit 10 år sedan
LICENSE 52a602da39 Initial commit 10 år sedan
README.md bd44e8fa80 Update README.md 10 år sedan
cover.out c93a5bbd96 初始化 10 år sedan
engine.go c93a5bbd96 初始化 10 år sedan
engineplus.go c93a5bbd96 初始化 10 år sedan
error.go c93a5bbd96 初始化 10 år sedan
goracle_driver.go c93a5bbd96 初始化 10 år sedan
helpers.go c93a5bbd96 初始化 10 år sedan
helpersplus.go c93a5bbd96 初始化 10 år sedan
logger.go c93a5bbd96 初始化 10 år sedan
lru_cacher.go c93a5bbd96 初始化 10 år sedan
memroy_store.go c93a5bbd96 初始化 10 år sedan
mssql_dialect.go c93a5bbd96 初始化 10 år sedan
mymysql_driver.go c93a5bbd96 初始化 10 år sedan
mysql_dialect.go c93a5bbd96 初始化 10 år sedan
mysql_driver.go c93a5bbd96 初始化 10 år sedan
oci8_driver.go c93a5bbd96 初始化 10 år sedan
odbc_driver.go c93a5bbd96 初始化 10 år sedan
oracle_dialect.go c93a5bbd96 初始化 10 år sedan
pg_reserved.txt c93a5bbd96 初始化 10 år sedan
postgres_dialect.go c93a5bbd96 初始化 10 år sedan
pq_driver.go c93a5bbd96 初始化 10 år sedan
processors.go c93a5bbd96 初始化 10 år sedan
rows.go c93a5bbd96 初始化 10 år sedan
session.go c93a5bbd96 初始化 10 år sedan
sessionplus.go c93a5bbd96 初始化 10 år sedan
sqlite3_dialect.go c93a5bbd96 初始化 10 år sedan
sqlite3_driver.go c93a5bbd96 初始化 10 år sedan
statement.go c93a5bbd96 初始化 10 år sedan
syslogger.go c93a5bbd96 初始化 10 år sedan
xorm.go c93a5bbd96 初始化 10 år sedan
xormplus.go c93a5bbd96 初始化 10 år sedan

README.md

xorm

优化xorm的查询API,并提供类似ibatis的配置文件及动态SQL功能

支持类似这样的链式操作

sql:="select id,title,createdatetime,content from article where id = ?"
rows, err := db.Sql(sql, 2).FindAll().Json()
或者
id := db.Sql(sql, 2).FindAll().Result[0]["id"]
title := db.Sql(sql, 2).FindAll().Result[0]["title"]
createdatetime := db.Sql(sql, 2).FindAll().Result[0]["createdatetime"]
content := db.Sql(sql, 2).FindAll().Result[0]["content"]

也支持SqlMa配置,配置文件样例

<sql id="selectAllArticle">
    select id,title,createdatetime,content 
    from article where id in (?1,?2)
</sql>
<sql id="selectStudentById1">
    select * from article where id=?id
</sql>

paramMap := map[string]interface{}{"1": 2, "2": 5}
rows, err := db.SqlMapClient("selectAllArticle", &paramMap).FindAllByParamMap().Xml()
同时提供动态SQL支持,使用pongo2模板引擎 例如配置文件名:select.example.stpl 配置内容如下:
select id,userid,title,createdatetime,content
from article where
{% if count>1%} id=?id {% else%} userid=?userid {% endif %}
paramMap := map[string]interface{}{"id": 2, "userid": 3, "count": 1}
rows, err := db.SqlTemplateClient("select.example.stpl", paramMap).FindAllByParamMap().Json()