mycat Sql注解
格式
真正执行 Sql
通过一条注解sql语句(通常是select)来确定真正执行的sql在哪个dataNode中执行
解决问题:
1. MySql 不支持的语法结构,如 insert …select…;
2. 同一个实例内的跨库关联查询,如用户库和平台库内的表关联;
3. 存储过程调用;
4. 表,存储过程创建。
注解规范
1. 注解 SQL 使用 select 语句,不允许使用 delete/update/insert 等语句;虽然 delete/update/insert 等 语句也能用在注解中,但这些语句在 Sql 处理中有额外的逻辑判断,从性能考虑,请使用 select 语句
2. 注解 SQL 禁用表关联语句;
3. 注解 SQL 尽量用最简单的 SQL 语句,如 select id from tab_a where id=’10000’;
4. 无论是原始 SQL 还是注解 SQL,禁止 DDL 语句;
5. 能不用注解的尽量不用;
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLicGcq5yYiRWZyczYwADZjJTZ4UDZmBjM3QjY4MGZ3UWN4AjN2Y2Mj9CX0VmbjN3bvwFdl5mLh5WaoN2cv5yZtl2Yz92Lc9CX6MHc0RHaiojIsJye.jpg)
e.g
存储过程:
CREATE PROCEDURE ‘test_proc’() BEGIN END ;
- 无返回值
call p_test(1,@pout)
2.返回普通 out 参数
set @pin=111;call p_test(@pin,@pout);select @pout
3.返回结果中有结果集时,则必须加注解,且注解中必须在 list_fields 中包括所有结果集参数名称,以逗号隔开 结果集参数必须在最后
表:
create table test2(id int);
Insert into …select
insert into t_user(id,name) select id,name from t_user2;
跨分片联合查询注解支持:
select * from order1 a,order_detail b where a.id=b.order_id
注:sam_glucose 是跨分片表;
存储过程注解支持:
CALL proc_test();
注:目前执行存储过程通过 mycat 注解的方式执行,注意需要把存储过程中的 sql 写到注解中;
批量插入与 ID 自增长结合的支持: insert into order1(sn) values('t1'),('t2');
注: 此方式不需要在 sql 语句中显示的设置主键字段,程序在后台根据 primaryKey 配置的主键列,自动生 成主键的 sequence 值并替换原 sql 中相关的列和值;
转载于:https://my.oschina.net/ziyou118/blog/1935406