डिफ़ॉल्ट मान यादृच्छिक स्ट्रिंग के साथ DB में कॉलम कैसे बनाएं


10

क्या मैं DB तालिका (PostgreSQL) में कॉलम बना सकता हूं जिसमें डिफ़ॉल्ट मान यादृच्छिक स्ट्रिंग है, और कैसे?

अगर संभव नहीं है, तो कृपया मुझे बताएं।


कृपया MySQL के लिए फिर से पूछें कि क्या आपको उस RDBMS के लिए भी जवाब चाहिए
जैक कहते हैं topanswers.xyz

जवाबों:


11

PostgreSQL उदाहरण:

CREATE OR REPLACE FUNCTION f_random_text(
    length integer
)
RETURNS text AS
$body$
WITH chars AS (
    SELECT unnest(string_to_array('A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 0 1 2 3 4 5 6 7 8 9', ' ')) AS _char
),
charlist AS
(
    SELECT _char FROM chars ORDER BY random() LIMIT $1
)
SELECT string_agg(_char, '')
FROM charlist
;
$body$
LANGUAGE sql;


DROP TABLE IF EXISTS tmp_test;


CREATE TEMPORARY TABLE tmp_test (
    id serial,
    data text default f_random_text(12)
);


INSERT INTO tmp_test
VALUES 
    (DEFAULT, DEFAULT),
    (DEFAULT, DEFAULT)
;


SELECT * FROM tmp_test;

 id |     data
----+--------------
  1 | RYMUJH4E0NIQ
  2 | 7U4029BOKAEJ
(2 rows)

जाहिरा तौर पर आप ऐसा कर सकते हैं। (बेशक, आप अन्य पात्रों के रूप में अच्छी तरह से जोड़ सकते हैं, या क्या वे भी अन्य यादृच्छिक स्ट्रिंग जनरेटर का उपयोग करें - जैसे यह । उदाहरण के लिए,)


1
चयन md5 (यादृच्छिक () :: पाठ); - यह बात है, धन्यवाद!
तस्मानीस्की

17

समाधान है (PGSQL के लिए):

alter TABLE users ADD column register_key text NOT NULL default md5(random()::text);

1
यह एक सुंदर चाल है!
cjauvin
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.