mycat通过注解实现不支持的sql执行

                                         mycat  Sql注解

格式

/*!mycat: sql=注解 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. 能不用注解的尽量不用;

 

c3f66085e7dc8b4720fd58e2cd00c72edbc.jpg

 

e.g

 

存储过程:

/*!mycat: sql=select 1 from test */ CREATE PROCEDURE ‘test_proc’() BEGIN END ;

 

  1. 无返回值

/*#mycat: sql=SELECT * FROM test */call p_test(1,@pout)

2.返回普通 out 参数

 /*#mycat: sql=SELECT * FROM test */ set @pin=111;call p_test(@pin,@pout);select @pout

3.返回结果中有结果集时,则必须加注解,且注解中必须在 list_fields 中包括所有结果集参数名称,以逗号隔开 结果集参数必须在最后

 /*#mycat: sql=SELECT * FROM test where id=1 ,list_fields=’@p_CURSOR,@p_CURSOR1’*/

 

表:

/*!mycat: sql=select 1 from test */create table test2(id int);

 

Insert into …select

/*!mycat: sql=select 1 from test */insert into t_user(id,name) select id,name from t_user2;

 

 跨分片联合查询注解支持:

/*!mycat:catlet=io.mycat.catlets.ShareJoin */

select * from order1 a,order_detail b where  a.id=b.order_id

注:sam_glucose 是跨分片表;

 

 存储过程注解支持:

/*!mycat: sql=select * from base_user where id_=1;*/ CALL proc_test();

注:目前执行存储过程通过 mycat 注解的方式执行,注意需要把存储过程中的 sql 写到注解中;

 

批量插入与 ID 自增长结合的支持:/*!mycat:catlet=io.mycat.route.sequence.BatchInsertSequence */ insert into order1(sn) values('t1'),('t2');

注: 此方式不需要在 sql 语句中显示的设置主键字段,程序在后台根据 primaryKey 配置的主键列,自动生 成主键的 sequence 值并替换原 sql 中相关的列和值;

 

 

转载于:https://my.oschina.net/ziyou118/blog/1935406

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值