Rails中给数据表添加字段,为啥没添加上

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Rails中给数据表添加字段,为啥没添加上相关的知识,希望对你有一定的参考价值。

参考技术A 在已有数据库中的表添加字段:
1、通用式:
alter table [表名] add [字段名] 字段属性 default 缺省值 default 是可选参数
2、增加字段:
alter table [表名] add 字段名 smallint default 0 增加数字字段,整型,缺省值为0
alter table [表名] add 字段名 int default 0 增加数字字段,长整型,缺省值为0
alter table [表名] add 字段名 single default 0 增加数字字段,单精度型,缺省值为0
alter table [表名] add 字段名 double default 0 增加数字字段,双精度型,缺省值为0
alter table [表名] add 字段名 Tinyint default 0 增加数字字段,字节型,缺省值为0
alter table [表名] add 字段名 text [null] 增加备注型字段,[null]可选参数
alter table [表名] add 字段名 memo [null] 增加备注型字段,[null]可选参数
alter table [表名] add 字段名 varchar(N) [null] 增加变长文本型字段 大小 为N(1~255)
alter table [表名] add 字段名 char [null] 增加定长文本型字段 大小固定为255
alter table [表名] add 字段名 Datetime default 函数 增加日期型字段,其中 函数 可以是 now(),date()等,表示缺省值
3、(上面都是最常用的,还有其他的属性,可以参考下面的数据类型描述)
4、删除字段:
alter table [表名] drop 字段名
修改变长文本型字段的大小:alter table [表名] alter 字段名 varchar(N)
删除表: drop table [表名]

mysql中给查询结果添加序号列

 

  成一个字段(非表中字段)用以记录排序   【类比为oracle数据库中的rownum】

    MySQL中一个表(表名:stuscore)

    字段有:id(主键)、stuid(学号)、sname(学生姓名)、subject(课程名称)、score(分数)

    

    列出数学成绩排名 (要求显示字段:排名,姓名 , 课程名称, 分数 , 学号)

    用于排名的字段,查询时此处将其用 pm表示

    

     select (@i:=@i+1)pm,s.* from stuscore s,(select @i:=0)t where s.subject=\'数学\'

    order by score desc;

    思想:事先定义一个变量,通过变量的递加以及虚拟表的联查达到生成序列号的目的。

    select * from table1,table2 不加任何条件时,是把两个表的数据笛卡尔积之后显示,

    如上sql中的  t  这张表  其实就是 一条 i=0 的数据

    mysql存储过程中,定义变量有两种方式:

    1、使用set或select直接赋值,变量名以 @开头

      赋值符号:使用set 时可以用 “=“或者“:=”     但是使用select赋值时必须使用“:=”赋值

      例如: set@id=1;

    可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。

    mysql总变量不用事先声明,在用的时候直接用@变量名 使用即可

   【先行记录】

    2以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:
          DECLARE var1 INT DEFAULT 0;

    主要用在存储过程中,或者是给存储传参数中

    两者的区别是:

      在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则

      不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在

      是这个会话内的全局变量。

    在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。
    例:
      set @v_sql= sqltext;
      PREPARE stmt FROM @v_sql;  
      EXECUTE stmt;     
      DEALLOCATE PREPARE stmt;

  

 

以上是关于Rails中给数据表添加字段,为啥没添加上的主要内容,如果未能解决你的问题,请参考以下文章

MySQL中给字段添加索引

mysql中给查询结果添加序号列

如何在ARCGIS中给图框4个角添加经纬度,例如下面的图片。

11--Rails数据交互3

ruby on rails 向数据库添加新字段

向 Rails 模型添加额外字段以减少不必要的数据库查询