Products

Solutions

Resources

Partners

Community

Blog

About

QA

Ideas Test

New Community Website

Ordinarily, you'd be at the right spot, but we've recently launched a brand new community website... For the community, by the community.

Yay... Take Me to the Community!

Welcome to the DNN Community Forums, your preferred source of online community support for all things related to DNN.
In order to participate you must be a registered DNNizen

HomeHomeUsing DNN Platf...Using DNN Platf...Using Modules a...Using Modules a...Extracting values form ProfileData in Profile Table in SQLExtracting values form ProfileData in Profile Table in SQL
Previous
 
Next
New Post
5/21/2012 10:10 AM
 

I have a SQL query that is returning a huge number of users (175,000) and I want to filter the results a bit more.

One of the ways of doing this would be to check the value of an item held in a users profile.profiledata field.

The field is called ProfileEmailAlert and looks like this

<item key="6882:ProfileEmailAlert" type="System.Boolean, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"><boolean>false</boolean></item>

I want to be able to access this via SQL, but have two issues

1) the data, although being XML, is stored in an NTEXT field.

2) The key is ModuleID:ProfileEmailAlert

So I would need a SQL query that would convert the NText to XML, then search for the item using the moduleID and name and then get the value (false in the example above).

Can anyone help me with the necessary SQL?

 
New Post
5/21/2012 11:40 AM
 
DNN profile data is stored serialized inside UserProfile table. no XML necessary.
I suggest having a look at http://userdirectory.codeplex.com/

Cheers from Germany,
Sebastian Leupold

dnnWerk - The DotNetNuke Experts   German Spoken DotNetNuke User Group

Speed up your DNN Websites with TurboDNN
 
New Post
5/21/2012 11:47 AM
 

We have custom modules with user personalisation. We have stored various module settings in the profiledata field within the profile table.

We use this code to extract the setting:

Dim objPersonalizationController As New PersonalizationController
objPersonalization = objPersonalizationController.LoadProfile(UserID, PortalID)
strDefault = GetProfile(objPersonalization, ModuleID.ToString, strSettingName)

and this code to update the setting:

SetProfile(PI, ModuleID.ToString, SettingName, SettingValue)

I now want to access these settings in SQL

 
New Post
5/21/2012 9:19 PM
 
AFAIK these settings are stored in userprofile table.

Cheers from Germany,
Sebastian Leupold

dnnWerk - The DotNetNuke Experts   German Spoken DotNetNuke User Group

Speed up your DNN Websites with TurboDNN
 
New Post
5/22/2012 3:42 AM
 
No, they are definitely in the profile table, held in the ProfileData field - I can see them clear enough, I just don;t know how to extract the values using SQL as the data type is NTEXT and the actual setting is XML.
 
Previous
 
Next
HomeHomeUsing DNN Platf...Using DNN Platf...Using Modules a...Using Modules a...Extracting values form ProfileData in Profile Table in SQLExtracting values form ProfileData in Profile Table in SQL


These Forums are dedicated to discussion of DNN Platform and Evoq Solutions.

For the benefit of the community and to protect the integrity of the ecosystem, please observe the following posting guidelines:

  1. No Advertising. This includes promotion of commercial and non-commercial products or services which are not directly related to DNN.
  2. No vendor trolling / poaching. If someone posts about a vendor issue, allow the vendor or other customers to respond. Any post that looks like trolling / poaching will be removed.
  3. Discussion or promotion of DNN Platform product releases under a different brand name are strictly prohibited.
  4. No Flaming or Trolling.
  5. No Profanity, Racism, or Prejudice.
  6. Site Moderators have the final word on approving / removing a thread or post or comment.
  7. English language posting only, please.
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out