mysql数据库字段中 判断字段中字符类型 问题

mysql数据库字段中 判断字段中字符类型 问题,第1张

您如果想要判断类型的话,可以进行转换 比如

select to_char(name) from table_name; ---这样就把您想要的数据NAME列转换为字符型;

select to_num(name) from table_name; ---这样就把您想要的数据NAME列转换为数字型;

您所说的自动判断 貌似没有

读取mysql数据库文本字段的值方法如下:

publicvoidread(){

try{

//连接数据库

conn=JdbcUtils();

//查询resume字段,text格式

Stringsql="selectresumefromtestclobwhereid=1";

pt=conn(sql);

//执行查询并返回结果

rs=pt();

if(rsnext()){

//rs读取该字段

Readerreader=rs("resume");

//定义字符数组来存放读取值

charbuffer[]=newchar[1024];

while((readerread(buffer))!=-1){

//打印

Systemoutprintln(buffer);

}

readerclose();

}

}catch(Exceptione){

e();

}finally{

JdbcUtilsrelease(conn,pt,rs);

}

}

mysql数据库里的日期用timestamp还是datetime好 (1)4个字节储存

(2)值以UTC格式保存

(3)时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。

(4)TIMESTAMP值不能早于1970或晚于2037!

timestamp在数据库里实际记载的时间是国际标准时间,同一个timestamp值在不同的时区检索出来的日期时间是不一样的,因为系统会根据时区的不同进行自动时区转换,而datetime则不会进行转换时区转换,存储时是什么日期时间,检索出来的就是存入时的日期时间,它不会有变化。至于这两种日期时间类型哪种好是没有定论的,要根据实际情况和应用需求做出取舍。

请注意由于无需实施时区转换,系统处理dateime所产生的系统开销要比timestamp小。

没什么好不好的,方便省事才是王道。都用datetime 你说呢,谁在乎那点存储

类型

类型 存储需求 格式 时间范围

datetime 8个字节 yyyy-mm-dd hh-mm-ss 1000-01-01 00:00:00 到9999-12-31 23:59:59 timestamp 4个字节 yyyy-mm-dd hh-mm-ss 1970-01-01 00:00:00 到2037-12-31 23:59:59

timestamp类型会有时区变量的影响,跨时区使用时应注意

datetime 8个字节 yyyy-mm-dd hh-mm-ss 1000-01-01 00:00:00 到9999-12-31 23:59:59

timestamp 4个字节 yyyy-mm-dd hh-mm-ss 1970-01-01 00:00:00 到2037-12-31 23:59:59

timestamp类型会有时区变量的影响,跨时区使用时应注意

没什么好不好的,方便省事才是王道。都用datetime 你说呢,谁在乎那点存储 类型 类型 存储需求 格式 时间范围 datetime 8个字节

Mysql中经常用来存储日期的数据类型有2种:Date、Datetime

1Date数据类型:用来存储没有时间的日期。Mysql获取和显示这个类型的格式为“YYYY-MM-DD”。支持的时间范围为“1000-00-00”到“9999-12-31”。

2Datetime类型:存储既有日期又有时间的数据。存储和显示的格式为 “YYYY-MM-DD HH:MM:SS”。支持的时间范围是“1000-00-00 00:00:00”到“9999-12-31 23:59:59”。

TIMESTAMP列用于INSERT或UPDATE *** 作时记录日期和时间。如果你不分配一个值,表中的第一个TIMESTAMP列自动设置为最近 *** 作的日期和时间。也可以通过分配一个NULL值,将TIMESTAMP列设置为当前的日期和时间。

TIMESTAMP值返回后显示为'YYYY-MM-DDHH:MM:SS'格式的字符串,显示宽度固定为19个字符。如果想要获得数字值,应在TIMESTAMP列添加+0。

注释:MySQL41以前使用的TIMESTAMP格式在MySQL51中不支持;关于旧格式的信息参见MySQL41参考手册。

datetime

1 占用8个字节

2 允许为空值,可以自定义值,系统不会自动修改其值。

3 实际格式储存(Just stores what you have stored and retrieves the same thing which you have stored)

4 与时区无关(It has nothing to deal with the TIMEZONE and Conversion)

5 不可以设定默认值,所以在不允许为空值的情况下,必须手动指定datetime字段的值才可以成功插入数据。

6 可以在指定datetime字段的值的时候使用now()变量来自动插入系统的当前时间。

结论:datetime类型适合用来记录数据的原始的创建时间,因为无论你怎么更改记录中其他字段的值,datetime字段的值都不会改变,除非你手动更改它。

timestamp

1 占用4个字节

2 允许为空值,但是不可以自定义值,所以为空值时没有任何意义。

3 TIMESTAMP值不能早于1970或晚于2037。这说明一个日期,例如'1968-01-01',虽然对于DATETIME或DATE值是有效的,但对于TIMESTAMP值却无效,如果分配给这样一个对象将被转换为0。

4值以UTC格式保存( it stores the number of milliseconds)

5时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。

6 默认值为CURRENT_TIMESTAMP(),其实也就是当前的系统时间。

7 数据库会自动修改其值,所以在插入记录时不需要指定timestamp字段的名称和timestamp字段的值,你只需要在设计表的时候添加一个timestamp字段即可,插入后该字段的值会自动变为当前系统时间。

8 以后任何时间修改表中的记录时,对应记录的timestamp值会自动被更新为当前的系统时间。

结论:timestamp类型适合用来记录数据的最后修改时间,因为只要你更改了记录中其他字段的值,timestamp字段的值都会被自动更新。

看完这个比较你就知道用哪个好啦

我们公司一般用datatime,可控性比较强

jdbc查询Mysql数据库的日期问题

你没说错!

查出来可以保存为String类型 具体转化一下就OK了

BBSXP 用的MYSQL数据库还是MSSQL数据库

BBSXP同时支持Aess数据库和MSSQL数据库

在Configasp文件里定义:

IsSqlDataBase=1 '定义数据库类别,0为Aess数据库,1为SQL数据库

不知道你是哪个版本,在BBSxp 2008 SP2里Configasp文件在根目录下。内容如下:

<%

InstallIPAddress="127001" '安装BBSXP的IP地址,针对installasp的访问权限

TablePrefix="BBSXP_" '数据库表的前辍名(一般不用更改)

IsSqlDataBase=0 '定义数据库类别,0为Aess数据库,1为SQL数据库

If IsSqlDataBase=0 Then

'''''''''''''''''''''''''''''' Aess数据库设置 '''''''''''''''''''''''''''''''''''''''''''''''''''''''''

SqlDataBase = "database/bbsxp2008mdb" '数据库路径

SqlProvider = "MicrosoftJetOLEDB40" '驱动程序[ MicrosoftJetOLEDB40 MicrosoftACEOLEDB120 ]

SqlPassword = "" 'ACCESS数据库密码

Connstr="Provider="&SqlProvider&";Jet Oledb:Database Password="&SqlPassword&"; Data Source="&ServerMapPath(SqlDataBase)

SqlNowString="Now()"

SqlChar="'"

IsSqlVer="ACCESS"

'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

Else

'''''''''''''''''''''''''''''' SQL数据库设置 ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

SqlLocalName = "(local)" '连接IP [ 本地用 (local) 外地用IP ]

SqlUserName = "sa" 'SQL用户名

SqlPassword = "1234" 'SQL用户密码

SqlDataBase = "bbsxp" '数据库名

SqlProvider = "SQLOLEDB" '驱动程序 [ SQLOLEDB SQLNCLI ]

ConnStr="Provider="&SqlProvider&"; User ID="&SqlUserName&"; Password="&SqlPassword&"; Initial CataLog="&SqlDataBase&"; Data Source="&SqlLocalName&";"

SqlNowString="GetDate()"

IsSqlVer="MSSQL"

'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

End If

'''''''''''''''''''''''''' 以下为专业人员设置选项,普通用户请勿修改 ''''''''''''''''''''''''''

SessionCodePage="936" '936(简体中文) 950(繁体中文) 65001(Unicode)

BBSxpCharset="GB2312" 'GB2312(简体中文) Big5(繁体中文) UTF-8(Unicode)

ResponseCharset=BBSxpCharset

ResponseBuffer=True

%>

注:

上面bbsxp7b1版本用的是Aess数据库,因为IsSqlDataBase=0

mysql数据库可以修改表的日期格式吗

日期型的字段 存储的格式是固定的不可以修改, 需要输出时 转换成需要的格式, 如果你不想输出时转换 那么需要 设为字符型的, 存储时转换 总之 不管先转还是后转 ,一定要转

public static void main(String[] args) throws ParseException

{

String str = "2013-11-01";

SimpleDateFormat s = new SimpleDateFormat("yyyy-MM-dd");

Date date = sparse(str);

}

然后这个转化后的date就可以随便转化成你需要的格式了

需要下载好的东西:MySQL-connector-java-503-binjar

在配置好MyEclipse的JSP基本环境后

开启apmserv后,配置MyEclipse的链接环境:window-open perspection-MyEclipse database exp新建一个链接,url处:jdbc:MySQL:(MySQL数据库链接),username和password是登录数据库的(不要弄错了)在finish前可以尝试链接,链接成功-finish链接失败注意看提示,一般是url的错误,多多尝试我用apmserv的url是jdbc:MySQL:127001/(数据库名)

之后在新建的web工程下,在WEB-INF\lib中improt-general-file system-选择MySQL-connector-java-503-binjar所在的文件夹-finish

使用下面的代码,可以测试链接,注意更改使用的数据库名,数据等

JDBCHelloWorldjava

import javasqlSQLException;

/

第一个 JDBC 的 HelloWorld 程序, 数据库访问 MySQL

/

public class JDBCHelloWorld {

/

@param args

@throws SQLException

/

public static void main(String[] args) throws SQLException {

// 1 注册驱动

try {

ClassforName("comMySQLjdbcDriver");

} catch (ClassNotFoundException e) {

// TODO Auto-generated catch block

eprintStackTrace();

}// MySQL 的驱动

// 2 获取数据库的连接

javasqlConnection conn = javasqlDriverManagergetConnection(

"jdbc:MySQL://localhost/testuseUnicode=true&characterEncoding=GBK", "root", null);

// 3 获取表达式

javasqlStatement stmt = conncreateStatement();

// 4 执行 SQL

javasqlResultSet rs = stmtexecuteQuery("select from user"); //这里是你要执行的SQL

// 5 显示结果集里面的数据

while(rsnext()) {

Systemoutprintln(rsgetInt(1));

Systemoutprintln(rsgetString("username"));

Systemoutprintln(rsgetString("password"));

Systemoutprintln();

}

// 6 释放资源

rsclose();

stmtclose();

connclose();

}

}

以上就是关于mysql数据库字段中 判断字段中字符类型 问题全部的内容,包括:mysql数据库字段中 判断字段中字符类型 问题、读取mysql数据库文本字段的值方法(mysql获取表字段信息)、mysql数据库里的日期用timestamp还是datetime好等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址:https://54852.com/sjk/9684409.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存