精华内容
下载资源
问答
  • SQL数据库字段数据类型说明

    千次阅读 2018-03-15 23:23:47
    SQL数据库常用字段数据类型说明这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。日期和时间数据类型MySQL数据类型含义date3字节,日期,格式:...

    SQL数据库常用字段数据类型说明

    这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。

    日期和时间数据类型


    MySQL数据类型含义
    date3字节,日期,格式:2014-09-18
    time3字节,时间,格式:08:42:30
    datetime8字节,日期时间,格式:2014-09-18 08:42:30
    timestamp4字节,自动存储记录修改的时间
    year1字节,年份

    数值数据类型

    整型

    MySQL数据类型含义(有符号)
    tinyint1字节,范围(-128~127)
    smallint2字节,范围(-32768~32767)
    mediumint3字节,范围(-8388608~8388607)
    int4字节,范围(-2147483648~2147483647)
    bigint8字节,范围(+-9.22*10的18次方)

    上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:

    tinyint unsigned的取值范围为0~255。

    浮点型

    MySQL数据类型含义
    float(m, d)4字节,单精度浮点型,m总个数,d小数位
    double(m, d)8字节,双精度浮点型,m总个数,d小数位
    decimal(m, d)decimal是存储为字符串的浮点数

    我在MySQL中建立了一个表,有一列为float(5, 3);做了以下试验:

    1.插入123.45678,最后查询得到的结果为99.999;
    2.插入123.456,最后查询结果为99.999;
    3.插入12.34567,最后查询结果为12.346;

    所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。

    字符串数据类型

    MySQL数据类型含义
    char(n)固定长度,最多255个字符
    varchar(n)可变长度,最多65535个字符
    tinytext可变长度,最多255个字符
    text可变长度,最多65535个字符
    mediumtext可变长度,最多2的24次方-1个字符
    longtext可变长度,最多2的32次方-1个字符

    1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。
    2.同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。
    3.超过char和varchar的n设置后,字符串会被截断。
    4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。
    5.char在存储的时候会截断尾部的空格,varchar和text不会。
    6.varchar会使用1-3个字节来存储长度,text不会。

    其它类型

    1.enum(“member1″, “member2″, … “member65535″)
    enum数据类型就是定义了一种枚举,最多包含65535个不同的成员。当定义了一个enum的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。如果声明了NOT NULL,则列表的第一个成员是默认值。

    2.set(“member”, “member2″, … “member64″)
    set数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。

    数据类型属性

    上面大概总结了MySQL中的数据类型,当然了,上面的总结肯定是不全面的,如果要非常全面的总结这些内容,好几篇文章都不够的。下面就再来总结一些常用的属性。

    1.auto_increment

    auto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。

    MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列。例如:

    代码如下:

    id smallint not null auto_increment primary key

    2.binary

    binary属性只用于char和varchar值。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。例如:

    代码如下:

    hostname char(25) binary not null

    3.default

    default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。例如:

    代码如下:

    subscribed enum('0', '1') not null default '0'

    4.index

    如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。以后针对输入条件可以搜索这个有序的键数组,与搜索整个未索引的表相比,这将在性能方面得到极大的提升。

    代码如下:

    create table employees
    (
    id varchar(9) not null,
    firstname varchar(15) not null,
    lastname varchar(25) not null,
    email varchar(45) not null,
    phone varchar(10) not null,
    index lastname(lastname),
    primary key(id)
    );

    我们也可以利用MySQL的create index命令在创建表之后增加索引:
    代码如下:

    create index lastname on employees (lastname(7));

    这一次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。因为使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。

    5.not null

    如果将一个列定义为not null,将不允许向该列插入null值。建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。

    6.null

    为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。记住,null精确的说法是“无”,而不是空字符串或0。

    7.primary key

    primary key属性用于确保指定行的唯一性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与行数据有任何关系,而只是作为一个唯一标识符。主键又分为以下两种:

    (1)单字段主键

    如果输入到数据库中的每行都已经有不可修改的唯一标识符,一般会使用单字段主键。注意,此主键一旦设置就不能再修改。

    (2)多字段主键

    如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。这时,多个字段联合起来确保唯一性。如果出现这种情况,指定一个auto_increment整数作为主键是更好的办法。

    8.unique

    被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。一般会指定一个列为unique,以确保该列的所有值都不同。例如:

    代码如下:

    email varchar(45) unique

    9.zerofill

    zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。例如:

    代码如下:

    orderid int unsigned zerofill not null


    展开全文
  • 修改数据库字段名称类型:alter table tableName rename column oldCName to newCName; -- 修改字段名 alter table tableName modify (cloumnName 数据类型); -- 修改数据类型1、创建表: CREATE TABLE TABLE_NAME...

    修改数据库字段名称类型:

    alter table tableName rename column oldCName to newCName; -- 修改字段名
    alter table tableName modify (cloumnName 数据类型); -- 修改数据类型

    1、创建表:

      CREATE TABLE TABLE_NAME(
        id varchar2(32) primary key,
        name varchar2(8) not null,
      );

    2、修改字段名:

      alter table TABLE_NAME rename name to re_name;

    3、修改数据类型:

      alter table table_name modify (id varchar2(64));

    4、创建视图:

         create or replace view view_name as select * from table_name

    5、查询数据库外键关联

    select *
    from user_constraints a, user_constraints b 
    where a.constraint_type = 'R' 
    and b.constraint_type = 'P' 
    and a.r_constraint_name = b.constraint_name
    --and a.CONSTRAINT_NAME like '%FK_DEL_IT_IN%'
    展开全文
  • 批量修改数据库字段类型(ORACLE)

    千次阅读 2017-02-10 17:03:51
    批量修改数据库字段类型,批量修改数据库数据类型
    DECLARE
    
      CURSOR TEMP IS SELECT TABLE_NAME,COLUMN_NAME,DATA_LENGTH FROM USER_TAB_COLUMNS WHERE DATA_TYPE = 'VARCHAR2';
      STR  VARCHAR2(100) := '';
    BEGIN
        FOR S IN TEMP LOOP
          STR := 'ALTER TABLE '||S.TABLE_NAME||' MODIFY('||S.COLUMN_NAME||' NVARCHAR2('||S.DATA_LENGTH||'))';
          DBMS_OUTPUT.PUT_LINE(STR);
        EXECUTE IMMEDIATE STR ;
        END LOOP;
    END;
    展开全文
  • 修改Oracle 有数据列的数据类型 方法一: // 创建一样的临时表 create table T_BUSINESS_MODEL_TEMP as select * from T_BUSINESS_MODEL where 1=2 ;  // 对临时表改数据类型 alter table T_BUSINESS_...

    修改Oracle 有数据列的数据类型

    方法一:


    // 创建一样的临时表

    create table T_BUSINESS_MODEL_TEMP  as select * from  T_BUSINESS_MODEL where 1=2 ; 

    // 对临时表改数据类型

    alter table T_BUSINESS_MODEL_TEMP modify MODEL_MONEY NUMBER(10,2);

    // 将原表数据赋值到最新的表中

    insert into T_BUSINESS_MODEL_TEMP select * from T_BUSINESS_MODEL; 

    // 删掉原来的表

    drop table T_BUSINESS_MODEL; 

    // 将临时表重新命名为原表

    alter table T_BUSINESS_MODEL_TEMP rename to T_BUSINESS_MODEL;

    // 添加原表的约束 (主键,外键,索引)

    alter table T_BUSINESS_MODEL
      add constraint PK_T_BUSINESS_MODEL primary key (ID);

    方法二:

    -- 字段重命名
    alter table PROJECT rename column NAME to NAME1;


    -----  把字段名称改成原来的名称
    alter table PROJECT add  NAME VARCHAR2(300);
    --- 赋值
    update PROJECT np 
    set np.name=np.name1;
    commit;
    --- 删掉原来重命名的字段
    alter table PROJECT drop column  NAME1;

    个人觉得还是方法二比较好一些!

    展开全文
  • 在研发新项目的过程中,需要不同人手去开发不同的功能,此时若没有严格要求sql表的字段类型,很容易出现字段类型长度...生成出来的结果,就是修改字段类型的语句了,复制,执行该语句即可 如有其他思路或者答案,欢迎讨
  • 可以用代码选择性连接数据库修改指定的字段类型,不需要打开数据库进行操作
  • 数据库字段数据类型

    千次阅读 热门讨论 2017-08-08 10:53:54
    字段数据类型 1.整数数据类型: bigint:整数值超过int数据范围时才可以使用 int:是将一个数值向下取整为最接近的整数的函数 smallint:需要 2 个字节存储的整数。 TINYINT : TINYINT 型的字段如果设置为...
  • Mysql修改字段名、修改字段类型

    万次阅读 多人点赞 2018-02-23 15:45:02
    mysql修改字段类型: ...ALTER TABLE 表名 MODIFY COLUMN 字段名 新数据类型 新类型长度 新默认值 新注释; -- COLUMN可以省略 alter table table1 modify column column1 decimal(10,1) DEFAULT NULL COMMENT '...
  • 修改数据库字段类型或名字

    千次阅读 2019-01-30 18:10:00
    ########WF_WORK_FLOW_LOG修改字段类型 1. ##修改字段名NAME为NAME_TMP 1 ALTER TABLE WF_WORK_FLOW_LOG RENAME COLUMN WORK_WHOLE_FLOW TO WORK_WHOLE_FLOW_TMP; 2.##增加一个和原字段名同名的字段NAME 1 ...
  • Oracle修改数据库字段

    2020-04-20 18:50:16
    Oracle修改数据库字段 字段没有数据或者要修改的新类型和原类型兼容时 alter table +表名+modify +字段名 +字段类型 例:alter table user modify name varchar2(100); 字段有数据并用要修改的新类型和原类型不兼容...
  • 我们在设计数据库的时候,往往需要注意数据库字段的类型和java的基本数据类型的对应关系,以便合理设计java实体;其实Mybaits里数据库字段类型 和java数据类型的转换,都是由一个个typeHandler进行转换,如:...
  • ALTER TABLE 表名 MODIFY COLUMN 字段数据类型 添加列 ALTER TABLEstudents ADD COLUMNaddressVARCHAR(100) DEFAULT NULL COMMENT '地址' 修改表students 增加字段address 长度100 默认为null 备注:地址 ...
  • mssql 修改数据库字段类型

    千次阅读 2018-10-12 09:00:23
    alter table tablename alter column columnname decimal(18,9)
  • 批量修改数据库字段数据类型

    千次阅读 2016-04-29 11:18:46
    在有些时候,需要将某种数据类型字段修改为另一种数据类型,可使用下列脚本实现;例如:原来定义为decimal(18,2)类型的所有统一修改为decimal(19,4)。 – 关闭 约束 declare tb cursor for SELECT sql=’...
  • sqlite数据库字段类型

    千次阅读 2020-03-25 14:30:39
    数据库字段类型: 字符型字段 topic=models.CharField(max_length=)#需要传入参数,设置字符串的最长长度 email=models.EmailTield()#电子邮箱字段,在CharField基础上,增加了邮箱的正则验证 a=models.SlugField()#...
  • 开发过程中经常会遇到数据库已经存有数据,但经过测试发现原来的表设计中字段格式不合适的问题,现在把修改的步骤以及经验总结一下,以供参考查阅
  • alter table 表名 modify 字段名...若有数据 ,数据库会报错错误报告 -ORA-01439: 要更改数据类型, 则要修改的列必须为空01439. 00000 - "column to be modified must be empty to change datatype"...
  • 数据库技巧-批量修改ORACLE数据库字段类型 如需转载请标明出处:http://blog.csdn.net/itas109 QQ技术交流群:12951803 使用工具: Navicat 11.2.7 1.新建过程函数 2.输入过程函数代码 这里的示例...
  • ORACLE数据库字段类型说明

    千次阅读 2018-04-03 17:08:36
    ORACLE数据库字段类型说明 目前Oracle 数据库大概有26个字段类型,大体分为六类,分别是字符串类型、数字数据类型、日期时间数据类型、大型对象(LOB)数据类型、RAW和LONG RAW数据类型、ROWID和UROWID数据...
  • gbase数据库更改字段类型

    万次阅读 2018-04-27 19:03:44
    背景:gbase数据库不支持直接修改列的数据类型如( ALTER TABLE t MODIFY b varchar(10) 这种语句),这里提供一个方法假设有表“t”有两个字段“a”“b”数据类型都为varchar(10)现在要将“b”的数据类型改为int...
  • 修改数据库字段

    千次阅读 2009-10-16 11:31:00
    1.修改字段数据类型:alter table [tablename] alter column columnname 字段类型 null2.添加一个字段:alter table [tablename] add columnname 字段类型 null3.修改字段名称:EXEC SP_RENAME tablename....
  • Access中的数据类型  Access中有10中数据类型:文本、备注、数值、日期/时间、货币、自动编号、是/否、OLE对象、超级链接、查询向导。 1、文本(Text(n)): 这种类型允许最大255个字符或数字,Access默认的大小...
  • 表是由sql server 转 为mysql , 字符类型的的所有字段都是longtext类型 , 将所有的longtext转为varcher类型
  • 数据库字段类型对应C#中的数据类型: 此处以SqlServer为例 数据库 C#程序  int int32  text string  bigint int64  binary System.Byte[]  bit Boolean  char string  d
  • 常用数据库字段类型

    千次阅读 2011-11-02 15:53:05
    常用的数据库字段类型如下: 字段类型 中文说明 限制条件 其它说明 CHAR 固定长度字符串 最大长度2000 bytes VARCHAR2 可变长度的字符串 最大长度4000 bytes可做索引的最大长度749 NCHAR 根据字符集而定的固定...
  • django系列3—数据库字段类型

    千次阅读 2020-06-15 22:05:08
    字段类型指使用Django ORM创建数据库时支持的数据字段类型。 常用字段 (1) AutoField 自增的整型字段,必填参数primary_key=True,则成为数据库的主键,无该字段时,django会自动创建主键id字段。 (2) BigAutoField ...
  • alter table web_app_base add tmp_col varchar2(3999);-- 添加临时列    update web_app_base set tmp_col = C_EDR_CTNT ; --将目标字段中数据加入到临时列中  ... --将目标字段数据清空   
  • SQL server 数据库 修改字段类型

    万次阅读 2019-08-16 16:14:16
    alter table表名alter column字段名称类型not null

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 420,392
精华内容 168,156
关键字:

修改数据库字段数据类型