数据库里什么数据类型能存放数组

数据库里什么数据类型能存放数组,第1张

1.char 和nchar 当填入数据为空时,数据库自动使用全空格来代替,从而使not null形同虚设。所以如果字段不能为空,一定要在程序中提前判断。

2.char 和nchar因为长度固定,据说读写的速度要比 varchar和nvarchar快 .

大概有25 种数据类型:

Binary [(n)],Varbinary [(n)],Char[(n)],Varchar[(n)],Nchar[(n)],Nvarchar[(n)],Datetime,Smalldatetime,Decimal[(p[,s])],Numeric[(p[,s])],Float[(n)],Real,Int,Smallint,Tinyint,Money,Smallmoney,Bit,CursorSysname,Timestamp,Uniqueidentifier,Text,Image,Ntext。

数组是编程语言里面的概念。

数据库,尤其是现在主流的“关系型数据库”,是专门用来存放表结构的。

所以标准的SQL语言,主要针对的是数据查询修改。

数据库里表的功能,已经足够强大。可以定义多个不同类型的列,甚至可以直接定义它是否允许重复等等。

这样的情况下,再强调数组的概念就没有任何意义了。因为数据库的用途不是编程,而是对数据进行管理。

如2楼所言。oracle所谓的定义数组,是因为它自带了plsql,也就是以标准sql语言为基础,面向过程的一种编程语言。这种语言可以编写一些procedure,function,package等等。

我们观察可以发现,plsql在使用上,就是一种面向过程的语言。它和普通sql语句的使用还是有极大的不同。因此它需要可以自定义一些东西。比如游标,比如参数,比如变量,比如返回值等等。

-------------------------------

所以你明白了吧,普通数据库使用的SQL语言里没有明确的直接定义“数组”的概念,是因为用途的不同。而plsql等用于编程的部分,则是有类似定义的。

--------------------------------------------------------------

补充说明,oracle表结构允许违背第一范式。但个人认为这并无推广意义。

SQL没有数组这种类型,数组是一种数据结构的概念,跟关系型mysql数据存储持久化没有关系。

如果要将数组的内容存储的mysql中,如 arr[n][m]二维数组,你创建一个table arr, 列是 A B,循环数组的每个元素,然后存储到对应的表中的A B列。

当然怎么存储到数据库中看你自己的需要,可以存到一个字段中,用分隔符分开,倒是取出来的时候直接字符串split得到数组。

扩展资料:

系统特性:

1、mySQL使用 C和 C++编写,并使用了多种编译器进行测试,保证了源代码的可移植性。

2、支持 AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种 *** 作系统。

3、为多种编程语言提供了 API。这些编程语言包括 C、C++、Python、Java、Perl、PHP、Eiffel、Ruby,.NET和 Tcl 等。

4、支持多线程,充分利用 CPU 资源。

5、优化的 SQL查询算法,有效地提高查询速度。

6、既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中。

7、提供多语言支持,常见的编码如中文的 GB 2312、BIG5,日文的 Shift_JIS等都可以用作数据表名和数据列名。

8、提供 TCP/IP、ODBC 和 JDBC等多种数据库连接途径。

9、提供用于管理、检查、优化数据库 *** 作的管理工具。

10、支持大型的数据库。可以处理拥有上千万条记录的大型数据库。

参考资料来源:百度百科-mySQL


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9939094.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存