SQL server2008,如何在建好的表中随机插入5条数据?
发布网友
发布时间:2022-04-09 07:41
我来回答
共2个回答
热心网友
时间:2022-04-09 09:10
1、对于MS SQL来说,任何一个表里的记录都是“没有顺序”的,如果有顺序,那只是为了便于存储。默认情况下,SQL服务器会按最便宜的方法将新的数据放入数据库的文件中,这个位置可能是服务器认为最便宜的位置。
2、对于MS SQL来说,用户要取数据的话,如果不指定排列顺序要求,那它就会按它认为最方便的检出顺序列出记录,这个记录顺序并不一定每回都是一样的。不过,如果你不重新起动SQL服务,且没有新的数据插入的话,这个记录顺序一般都是一样的。
3、对于有排序要求的输出来说,你应该指定排列顺序,事实上,多数人在设计数据库时,会加入一个自增字段,这个字段每次加入新的记录时就会自增其数值,即便删除了记录,新的记录的数值也不会与曾经有过的数值重复,你想要将这些数值重新理顺的话,唯一方法是将这个字段删去后重建一个相同的字段。
4、如果你是想偷偷的做坏事不想让人发现,个人建议你别在重要的数据库中干坏事,否则后果可能会很严重哦。绝大多数企业级数据库是会有定时备份的,专业人员是能发现问题的。此外,大型数据库的很多表是相互关联印证的,并不是改一个表就可以了,强行修改的结果一般都是引起整个系统的故障。追问
追答那你就直接插入就好,可以忽略随机二字。
热心网友
时间:2022-04-09 10:28
这问题好难回答,怎么个随机法?又不是随机数,怎么随?
要遵从相关业务需求。。。。。追问
追答那好办,用random随机数
MSSQL有个函数CHAR()是将int(0-255) ASCII代码转换为字符。可以随机生成小写、大写字母,特殊字符和数字。
大写字母:
CHAR(ROUND(RAND() * 25 + 65,0))
小写字母:
CHAR(ROUND(RAND() * 25 + 97,0))
特殊字符:
CHAR(ROUND(RAND() * 13 + 33,0))
数字:
CHAR(ROUND(RAND() * 9 +
48,0))
TradeID是Int倒是之间随就行了,至于时间嘛,只要取当前时间再加上个随机数就ok