xorm官方中文文档 参考 http://xorm.io/docs/

以sqlserver为例

先初始化连接等...

engine, err := xorm.NewEngine("mssql", "server=127.0.0.1;user id=sa;password=123456;database=dbname")
//控制台打印SQL语句
engine.ShowSQL(true)
if err != nil {
fmt.Println(err)
}
defer engine.Close()

一、查询案例

ids := []model.MsIdcaid{}   //实体定义的话自己写
engine.Cols("Id", "Address").Where("id in(2,3,4,5,6)").OrderBy("id desc,address asc").Find(&ids)
//[SQL] SELECT "Id", "Address" FROM "cdsgus" WHERE (id in(2,3,4,5,6)) ORDER BY id desc,address asc

或者直接自己写SQL

engine.SQL("SELECT Address from cdsgus where id in (2,3,4,6) order by id desc ").Find(&ids)
//[SQL] SELECT Address from cdsgus where id in (2,3,4,6) order by id desc

二、分页查询

方式一 :用Limit(int i,int j) 方法, i=要取的条数, j=开始的位置

MSSQL 虽然执行的结果正确,可以看到生成的分页SQL很乱,建议直接MSSQL分页直接用方式二写在SQL里。其他数据库应该是没有问题, 如:mysql

其实本文用数据库的版本SQL2014 是支持:OFFSET 2 ROW FETCH NEXT 10 ROW ONLY的写法的,xorm并未识别数据库的版本调整分页SQL

engine.Cols("Id", "Name").Where("id in(2,3,4,5,6)").OrderBy("id desc,address asc").Limit(10, 2).Find(&ids)
//[[SQL] SELECT TOP 10 "Id", "Name" FROM "cdsgus" WHERE (id in(2,3,4,5,6)) AND (id NOT IN (SELECT TOP 2 id FROM "cdsgus" WHERE (id in(2,3,4,5,6)) ORDER BY id desc,address asc)) ORDER BY id desc,address asc

方式二 :用原生的SQL方法 ,很妥

engine.SQL("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) order by id desc OFFSET 2 ROW  FETCH NEXT 10 ROW ONLY").Find(&ids)
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6) order by id desc OFFSET 2 ROW FETCH NEXT 10 ROW ONLY

方式三 :用原生的SQL + Limit 方法 ??MSSQL居然是错误SQL&结果

engine.Sql("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) ").OrderBy("id").Limit(10, 2).Find(&ids)
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6)
data, _ := engine.Sql("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) ").OrderBy("id").Limit(10, 2).Query()
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6)

方式四 : github.com/go-xorm/builder

最新文章

  1. 【目录】JUC锁框架目录
  2. 15 Best Responsive HTML5 Frameworks 2014
  3. python 简单爬虫diy
  4. 正则的小效果:-------> 过滤敏感词
  5. 51nod1253 Kundu and Tree
  6. UCTF Final-Hackventure
  7. vijos P1352 最大获利(最小割)
  8. [android更新类的内容开发APP]四、项目布局的基本功能(继续)
  9. POJ 1845 Sumdiv#质因数分解+二分
  10. Python 调用让系统自动调用默认程序打开文件?
  11. BZOJ_1834_[ZJOI2010]network 网络扩容_费用流
  12. MySQL 还原
  13. Java工具类——UUIDUtils
  14. PHP array_combine()
  15. 超细讲解Django打造大型企业官网
  16. html跳页面传值
  17. 〖Linux〗Shell十进制数值转换十六进制
  18. SPI、I2C、UART三种串行总线协议的区别和SPI接口介绍(转)
  19. python下编译py成pyc和pyo和pyd
  20. load/domContentLoaded事件、异步/延迟Js 与DOM解析

热门文章

  1. 【jenkins】【java】【tomcat】windows host key verification failed
  2. JZOJ 5462. 【NOIP2017提高A组冲刺11.8】好文章
  3. Pychram基本操作
  4. Python9-MySQL-Homework-day43
  5. manjaro中文输入法已安装但切换不了解决方法
  6. FLASH、SDRAM
  7. 1、IOS学习计划
  8. 53、listview、expandableListview如何选中时保持高亮?
  9. 【palindrome partitioning II】cpp
  10. 【SCOI 2010】股票交易