- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对mysql有疑问。我可以轻松地将字段限制为某些字符,例如姓氏,以及其他字段,例如包含特定事件的迷你日志,我认为该事件不再是 2 页(或更少的字符)。我知道这是一个相当常见的问题,我看到了很多关于这个问题的链接,但我看不出有什么区别和正确的方法。
以下是我的结论和疑问,如有错误请指正:
-varchar 是一个变量类型,如果我设置 varchar(10) 或 varchar(65535),没关系,尽管不是相同的 65536,它通过到中等文本。-varchar 与一个或多个参数是相同的,只占用必要的空间,它只是保存的限制和表示的限制。
-如果我在应用程序一侧进行限制,它是完全相同的并且更灵活。
-text是固定长度的,如果我设置text的话,无论我使用还是不使用,它都会占用65535。
varchar
- 它有一个重载,必须首先找到字段的长度是多少。
- 在节省长度的情况下,它的成本多了一个字节。
- 它是内联保存,这意味着在表中。
-它始终具有更好的性能。
文字
-它存储在表之外,有一个指向我的文本的指针,是这样吗?
- 它有固定数量的字符。
-在 varchar 和 text 中设置的长度是以字符为单位,而不是以字节为单位(以前的版本不同)
-出于这些原因,始终使用 varchar 会更好,只有一种情况是不正确的,即我确切知道字符数的情况。
所有其他最常见的情况,最好使用最长的 varchar,因此它适用于名称或姓氏(虽然我可以将其限制为 text(35),但我不知道名称是否是“Tom”或“Federico Guillermo Rodrigo Cayetano”),对于现场问题或描述(更多变量),或者对于像迷你日志这样更大的文本,其长度可以从 0 到 3 页字符不等(这就是我的情况) ,但我们可以把它发挥到极致,比如 0 到 16 页文本,大约 65535 个字符)。这是正确的,特别是如果我们无法知道 future 的需求,比如最长的描述,如果我们限制表空间,需求的改变可能是一个难题。
最后,就像一个奖励:),如果文本超过 65535 个字符但谁可以改变会发生什么?将其设置为中等文本或长文本(如果可以改变)是合理的吗?
最佳答案
我认为你的假设并不完全正确,可能过于偏执或被不再有效的历史担忧所玷污。
通常最好使用 VARCHAR
,因为 MySQL 和其他数据库引擎已经过优化,可以很好地处理它们。从历史上看(1990 年代),使用具有固定长度行的表与使用可变长度行的表时存在显着的性能差异,但如今已不再需要担心。
同样,TEXT
列过去将所有数据存储在主表数据的外部。现在我相信使用了一种混合方法,前 N 个字符存储在行中,剩余的字符存储在 BLOB 系统中(如有必要)。根据定义它是可变长度的,单个字符不使用65535字节来存储。
对于更大的文本 block ,您需要使用 LONGTEXT
,但此时您应该评估是否正确使用数据库。在其中存储、检索和操作巨大的物体可能会带来严重的麻烦。
默认情况下,我会使用 VARCHAR(255)
表示任何“文本”,并在必要时将其延长。除了非常有限的情况外,缩短通常会出现问题,例如您存储的 ISO 国家/地区代码根据定义为两个字符。
假设名称“不超过 32 个字符”几乎总是一个错误的假设。除非您有充分的理由不这样做,否则请将这些内容保持开放。
您可能认为城市或地名之类的东西也很短,但是 you'd be wrong 。世界是一个奇怪的地方。期待意想不到的事情。
关于php - mysql varchar 和 text 疑问,重新加载;),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34731046/
我目前正在创建一个正则表达式来拆分所有匹配以下格式的字符串:&[text(text - text text) !text]。这里的文本实际上可以是任何字符。并且间距很重要。文本将如图所示列出。 我已经
这个问题在这里已经有了答案: Remove duplicate commas and extra commas at start/end with RegExp in Javascript, and
我有以下代码。 from xml.dom.minidom import Document doc = Document() root = doc.createElement('root') doc.a
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Find text string in jQuery and make it bold 如何使用 jQuer
我使用 libmagic 在我的元素的 Web 界面中获取文件的 MIME 类型。我在 css 和 js 文件上得到文本/纯 mime 类型。 例如 chromium 显示以下警告: Resource
起初我必须阅读很多教程,但我仍然不知道我做错了什么...... 我想内联使用 4 个 div。在我想放置的那些 div 中:文本、图像、文本、文本。我希望中间文本自动设置为最大宽度。 我写了一个简单的
我想替换所有出现的 [b: "text"]至text使用 JavaScript 和 RegEx。目前我知道如何替换 [b: ""]至使用'/\[b: ""\]/g'但我不知道如果 " 之间有文本该怎么
这可能是一个幼稚的问题,但我想知道是否有比使用 text() 更好的方法将文本添加到绘图中。注意,我也在使用 layout()以及。具体来说,我有一个情节的一部分,我想在其中添加一些带有标题的文本,然
我必须反复从 latex 源粘贴代码,因此每次都必须做很多查找和替换操作('“a'=>'ä','” o'=>'ö',...) 。 有没有一种方法可以存储这些搜索和替换规则,例如,我可以通过一次按键执行
当我在Sublime Text 3代码屏幕中编写代码时,它连续地向右滑动,如图所示。我该怎么办? 请注意第10行。 最佳答案 如果您只想为当前 View (正在编辑的当前文件)激活自动换行,只需vie
是否有可能更改 sublime text 中的默认字体目录?我只想使用可移植 sublime 文本存储在我的 pendrive 上的字体,这样我就不必在我使用可移植 sublime 文本的每台机器上安
我是 Android 开发的新手,我有一个愚蠢的问题。如何将“文本字段”框放在一行中的文本旁边。 例子: Please Enter the number: [ ] 关于 "t
我想自动将“我的文本”更改为“我的文本”,因为这是用德语写的正确方式。引号可以在文本中的任何位置。 有没有一种简单的方法可以实现这一点? 解决方案应该检查第一个字符,最后一个字符,比如“this”,或
我想知道是否有特殊的语法来绑定(bind)与现有文本连接的文本。 像这样。 显然,这行不通。 什么是最佳实践? 使用 SL4。 最佳答案 使用StringFormat在 Binding 上。 WPF
我认为它应该打印“真实文本”,因为它相当于 true console.log('true text' || true ? 'text' : 'text1'); 但是,输出是“文本”;抱歉,如果是愚蠢的
有没有办法通过 css 打破文本,以便中间有一个“空白”?目前我正在通过手工打破文本来解决这个问题 -但这是愚蠢的。我知道有一个函数可以让文本在另一个 div 中结束和开始,但 IE 不支持它。 文本
我想为我的Tcl/Tk工具实现一个效果:在text控件中,根据具体情况,希望高亮一些线条的背景色,其他线条正常透明.有可能吗? 我尝试了一些选项,例如:-highlightbackground 、-i
我正在尝试解析原始维基百科文章内容,例如the article on Sweden ,使用re.sub()。但是,我在尝试替换 {{some text}} block 时遇到了问题,因为它们可以包含更
我试图先删除 ComboBox 中的所有内容。然后在其前面添加文本,但保留了一些旧文本。有没有办法重置或清除 ComboBox?或者我怎样才能最好地实现这一目标? public void GetBad
我知道我们应该创建 Example对象并将其传递给 nlp.update() 方法。根据 docs 中的示例, 我们有 for raw_text, entity_offsets in train_da
我是一名优秀的程序员,十分优秀!